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1 . General Description 



1.1 Overview 



The SDC-RQD11-SCH is a high performance quad height interface to SMD com- 
patible disk drives. The SDC-RQD11-SCH can support one or two SMD drives and 
features a one megabyte cache memory, 24 megabit per second throughput, com- 
mand queuing, overlapped seeks, and implements DEC's Mass Storage Control 
Protocol (MSCP). 1 

The SDC-RQD11-SCH flexibly couples disks of any size and data rate to all stand- 
ard DEC operating systems without software modification. Comprehensive on-board 
interactive formatting and diagnostic firmware provides engineering support across 
the range of LSI-11, MicroVAX and various non DEC implementations of the Q- 
bus. 2 

Two SMD Drives up to 3 Megabytes/Second Transfer Rate 

The SMD interface is an industry standard for high capacity disk drives. There have 
been modifications to this standard by various manufacturers. The SDC-RQD11- 
SCH supports Standard, Modified, Enhanced and Extended SMD interfaces with 
no software or hardware changes. Two drives of any type with transfer rates of up 
to 24 megabits per second (3 megabytes per second) are supported. 

One Megabyte Disk Cache 

All data is read from and written into the cache. Data transfers from the cache are 
approximately 2.5 ms compared to 30 - 38 ms for typical drive access times - up to 
an 93 percent reduction in access time. The cache memory acts as a track buffer and 
can provide data at rates of 3 megabytes per second. 



1 Q-bus, MSCP, RSX-11, RT-11, RSTS/E, VAX/VMS, and MicroVAX are registered 
trademarks of Digital Equipment Corporation. 

2 REF: \WORK\SMDSCHxC 
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No Sector Interleaving 

The SDC-RQD11-SCH stages all data from the disk drive through the cache 
memory. This ensures that all data can be transferred at full disk speed over the 
disk interface and at maximum speed over the Q-bus without incurring data late er- 
rors. Disk and Q-bus transfers are performed simultaneously to minimize access 
times. 

Read Look-ahead 

The SDC-RQD11-SCH allows the user to program the controller to perform 'look- 
ahead' reads in anticipation of data requests. Whole tracks or more can be read into 
the cache ensuring that data is ready for the host computer the instant it is needed. 

Virtual Units 

The SDC-RQD11-SCH also allows the user to partition each drive into virtual units 
which are addressed by the host as individual drives. Each virtual unit can be any 
size up to the size of the entire drive with up to 16 virtual units assigned to each con- 
troller. Each virtual unit can be further partitioned under the host operating system. 

Block mode DMA and DMA Throttle 

With Block Mode DMA, the SDC-RQD11-SCH interleaves address references with 
bursts of data - almost doubling Q-bus throughput. The SDC-RQD11-SCH fully con- 
forms with Q-bus Block Mode DMA protocol. With non block mode memory, the 
SDC-RQD11-SCH automatically reverts to burst mode DMA. 

After every 16 word DMA transfer there is a 4 microsecond delay to service any 
pending interrupt or DMA requests from other devices. If a DMA request occurs a 
'DMA throttle' will release the Q-bus after 8 words to prevent data loss from other 
DMA devices. 

Drive Shadowing 

The SDC-RQD11-SCH offers the user the option of drive shadowing. Data integrity 
is further improved by writing the same data to two drives simultaneously. In certain 
circumstances greater data throughput may be achieved because the controller can 
decide which drive has its heads positioned closest to the required data, and 
schedule a read on that drive. 

Seek Optimization and Overlap 

The SDC-RQD11-SCH can queue up to 32 commands. The optimum order of ex- 
ecution is dynamically computed according to the strategy selected by the user. With 
multiple disk drives seeks are initiated simultaneously, further improving perfor- 
mance. 

Error Checking and Correction 

The SDC-RQD11-SCH uses a 48-bit ECC polynomial with an 11-bit correction span 
for error detection and correction. The SDC-RQD11-SCH will try up to 10 times to 
correct an error before reporting the fault to the host system. 
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Dynamic Bad Block Replacement 

The SDC-RQD11-SCH dynamic bad block replacement and error correction always 
presents error free 'perfect media' to the host computer. During normal operation 
the controller dynamically replaces any blocks it detects as bad with an alternative 
block from a replacement block pool. Blocks with hard errors are replaced but the 
data in them flagged 'forced error.' This indicates to the host that though the data in 
these blocks is bad the blocks themselves are now good. All bad block replacement 
is completely invisible to the host computer. 

Statistics Recording 

The SDC-RQD11-SCH records statistics such as the number of reads and writes, 
cache hits and misses, and other important information for each drive. The user can 
interrogate the drive for this information according to application specific perfor- 
mance requirements. 

Write Protect 

A connector is provided to which the user can connect one write protect switch per 
drive. 

MSCP Emulation 

The SDC-RQD11-SCH communicates with the host through a simple register pair 
to memory resident 'command packets.' Disk geometry factors such as sectors, 
heads, cylinders and disk capacity are invisible to the host computer. The SDC- 
RQD11-SCH accepts 32 bit binary block numbers and converts them to physical 
disk addresses, allowing any size disk to be fully accessed by any program without 
software modification. 

Supported operating systems include RT-11 version 5; RSX-llM-Plus version 2; 
TSX-Plus version 5; RSTS/E version 8; MicroVMS version 4; or later versions. 
Various UNIX versions are also supported. 

Q-bus interface 

Originally introduced in 1975 by Digital Equipment Corporation to support the LSI- 
11 CPU range, the Q-bus architecture has evolved in speed and function to the 
point where it now outperforms most small computer bus systems. The SDC- 
RQD11-SCH fully implements all current Q-bus enhancements, including block 
mode transfers, 4- level interrupt structure, 22 bit addressing, and fully supports 
LSI11/2, LSI11/23, LSI11/73 and MicroVAX II Q-bus CPU designs. 

On-Board WOMBAT Utilities 

WOMBAT is an interactive formatting and diagnostic utility contained within the 
SDC-RQD11-SCH firmware. An on-board serial connection allows WOMBAT to 
be run using an ASCII terminal. This permits disk formatting and maintenance 
operations to be carried out with minimal additional hardware. 
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WOMBAT can also load a simple console communication program into the host 
computer's memory or it can be invoked on system power-up. No external software, 
media, or program loading device is required in maintenance of the SDC-RQD11- 
SCH or its attached disk drives. WOMBAT is always available independently of the 
host CPU type or the operating system environment. 

WOMBAT Formatter 

WOMBAT initializes a fresh disk drive by writing sector addresses and zero data 
blocks through the entire recording surface. WOMBAT prompts the user at the ter- 
minal to supply parameters such as drive geometry (cylinders, heads and sectors) 
and various other options. This data is stored twice in special reserved areas of track 
zero and retrieved by a simple homeseek-read sequence at each power-up. No spe- 
cial PROMs or switch settings are required to fully characterize the connected disk 
drives. 

WOMBAT Self Diagnostics 

The SDC-RQD11-SCH contains a comprehensive set of self diagnostic procedures 
which are executed automatically on power-up. Failure is indicated by a flashing red 
LED and a fatal error status which is deposited in the SA register. 

WOMBAT Interactive Diagnostics 

Terminal oriented engineering utilities contained within the WOMBAT firmware in- 
clude a continuous read/write/seek exerciser, a disk surface pattern tester and a bad 
block replacement routine. 

Sequential Spin-up 

The SDC-RQD11-SCH controller will spin-up SMD drives in a sequential manner, 
providing they have the "motor control" option enabled. This is done to minimize 
start-up current surge. 



1.2 Specifications 



Bus Interface: DEC Q-bus 

Bus Loading: 1 DC load, 2 AC loads. 

Bus Interface Logic: DEC approved AMD 2908 and National 88641 only. 

Transfer Mode: Block and burst mode supported. 

Block Transfer Time: 10.8jjls. TSACK active time for 16-word read block 

transfer. 

Block Transfer Delay: 4jxs (min) between block transfers. 
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Word Transfer/Block: 

DMA Address 
Capacity: 

CSR Address Selection: 

Interrupt Priority Level: 

Interrupt Vector Add: 

Software Interface: 

Disk Transfer 
Overhead: 

Cache Read Execution 
Time: 



Boot Address: 

Ring Buffer Capacity: 

Special Features: 
WOMBAT Utilities: 

Disk Cache: 



Cache Assignment 
Algorithm: 

Cache High Rate: 



16 if no DMA request pending. 
■8 if other DMA request pending. 
4MB (22-bit) 

63 addresses (jumper selectable). 

4 through 7 (jumper selectable). 

Software selectable. 

Full DEC MSCP emulation (DU:) 

Total = 2.9 ms (1 block read execution time less drive 
seek, latency, and data transfer times). 

Total = 2.3 ms (1 block read from IP read initiation 
to completion interrupt). 

Overhead = 2.04ms 

DMA transfer = 260jxs. 

177773000, 17771000, disable (jumpered). 

Default = 8 (32 commands maximum). WOMBAT 
selectable. 



Extensive built-in utilities to structure, format and test 
disk/controller, and acquire operational statistics. 

Size = 1MB (with parity) Optimized for typical 
operating system environment. Can increase overall 
system performance 50% or more. 

A contention based hashing algorithm optimized for 
typical operating system transfer sizes. 

Hit rates up to 80% or more in typical operating sys- 
tem environments. 
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Read Look-ahead: 
Head Spiraling: 
Overlap Seek: 
Seek Optimization: 



Bad Block Mapping: 
WOMBAT Entry: 



MSCP Operation: 

Error Check and 
correcting (ECC): 

Drive shadowing: 



Self Diagnostics: 
Operating Statistics: 

PDP-11 Boot Program: 
LED Indicators: 

External Panel: 
LEDs: 
Controls: 



Default is 4. WOMBAT selectable. 

Default is 4. WOMBAT selectable. 

Supported for multiple drives. 

WOMBAT selectable schemes are: 

None Nearest 

Elevator Forward 

Displayed and entered via: 

Manual: enter block number 

Automatic: insert from test statistics 

Direct: key in from disk defect map 

Dynamic: during MSCP operation. 

48-bit wide ECC with an 11-bit correction span vs nor- 
mal 32-bit wide. Provides extra margin of reliability. 

Automatic, redundant write duplication on second 
drive (optional). 

Self-test on power-up and via WOMBAT includes in- 
teractive command building utility for troubleshooting. 

Includes disk seek times, number of writes/reads, and 
cache hits for system tuning and analysis. Via WOM- 
BAT. 

Built in for most DEC mass storage devices. 

Two red - Fatal Error 

Two green - Disk Access in Progress. 

Active or passive. 

Supports one Access in Progress per drive. 

Supports on Write Protect and one on-line/off-line per 
drive. 
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RS-232 Port: 
Drive Interface: 

Number of Drives: 
Transfer Rate: 
Data Interface: 

Data Interface Logic: 
Physical & Electrical: 

Dimensions: 

Power Requirements: 
Environmental: 

Temperature: 

Humidity: 
Altitude: 



9600 baud. Off-line WOMBAT operation. 

CDC SMD (standard modified, enhanced, and ex- 
tended). 

Two (maximum). 

3.125MByte (25Mbits) maximum. 

Meets or exceeds CDC specification #64712402 REV 
D (24 Mbit transfer rate). 

Motorola MECL type. 



Standard Q-bus quad-wide board. 
+ 5VDC @ 6.1A, + 12VDC @ 0.2A. 

Operating 0°C to 50°C 
Storage -40°C to 85°C 
10% to 95% non-condensing. 
Operating -200 ft. to 10,000 ft. 
Storage -200 ft. to 30,000 ft. 
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2. Installation 



2.1 Unpacking and Inspection 



The SDC-RQD11-SCH is shipped in a special packing carton designed to keep the 
module from vibrating and to give it maximum protection during shipment. The 
packing carton should be retained in case the unit requires reshipment. The packing 
carton should contain the following: 

P/N 400995 SDC-RQD11-SCH quad-wide module 

MA400995 Manual entitled "SDC-RQD11-SCH, MSCP Compatible Disk Con- 

troller for LSI-11 and MicroVAX Systems" 

P/N 501017 Optional single drive configuration cable kit with one 26-pin data 

cables and one 60-pin control cable 

P/N 501018 Optional dual drive configuration cable kit with two 26-pin data 

cables and one 60-pin control cable daisy chained to second drive 
(controller-to-drive-to-drive) 

P/N 501020 Optional dual drive configuration cable kit with two 26-pin data 

cables and two 60-pin control cables (controller- to-drive and drive- 
to-drive) 

P/N 501019 Optional maintenance adapter 

Unpack the SDC-RQD11-SCH and visually inspect for physical damage. If any 
damage has occurred, contact the factory immediately. 



2.2 Factory Configurations 



The SDC-RQD11-SCH is shipped with switch and jumper configurations as shown 
in Figure 2-1. Verify that these configurations are correct. If other configurations 
are required, refer to the appropriate paragraphs in this section. 
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Jumper Conjurations Installation 



Figure 2-1: 

Jumper 

Configurations 




icr 



BOOT 
<B1-B3) 

ENABLED <BZ IN) 



CSR ADDRESS 

17772150 

(Al-AS IN) 



n 



REF SMDSCH21 



Jl 



FIXED _ 
MEDIA TYPE 
(Hl-HO IN) 
W 



tl 

CPU TYPEO 
(S0-S1 IN) 



INTERRUPT 

LEVEL 4 

111 

(P1--P3 IN) 



Jl 



2.3 Jumper Configurations 
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The SDC-RQD11-SCH can be configured with a combination of configuration 
jumpers. Jumper positions for base (CSR) address, automatic bootstrap selection, 
interrupt priority, removable media, and CPU type are given in the following 
paragraphs. 

2.3.1 Base (CSR) Address and Interrupt Level 

Jumpers Al through A6 determine the CSR address. 

Figure 2-2 shows the location of the standard CSR address (17772150) configuration 
jumpers. Appendix A contains a complete list of the CSR address. 

The address selected by the Micro VAX depends on the overall configuration and 
can be determined by using the CONFIGURE option of the SYSGEN program 
(Chapter 5). This allows you to tell the MicroVAX what you intend to install and it 
will tell you what the CSR (and vector) addresses must be. 

The interrupt priority can be set for level 4, 5, 6 or 7 by installing jumper PI, P2 or 
P3 as shown in Figure 2-2. 
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Figure 2-2: 
CSR Address and 
Interrupt Level 
Configurations 



VT1 



CONTROL CABLE 
CONNECTOR 



stx 




REP SMDSCH22 



INTERRUPT PRIORITY LEVEL 



(FACTORY SET) 

LEVEL 4 LEVEL 5 

1 1 1 : i i 

P1 P2 P3 P1 P2 P3 

LEVEL 6 LEVEL 7 

i : : i : i 

PI P2 P3 P1 P2 P3 



C5R ADDRE5S SELECTION 
(SEE APPENDIX A) 



•-» A1 

•-• A2 

•-• A3 

•-» A4 

•-« A5 

•-» A6 

(FACTORY SET) 



2.3.2 Automatic Bootstrap Select 

The automatic bootstrap is for LSI-11 processors only. If this option is used then 
CPU type must be set to zero. (See Figure 2-4.) 

See Section 2.6 for bootstrap operation. 



Figure 2-3: 
Media Type and 
CPU Type 



ON-BOARD BOOT (LSI-11 ONLY) 
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B2 • • 

B3 " * 
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DISABLED 
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ii 17773000 

(FACTORY SET) 



B1 » • BOOT ENABLED 
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ccmTfiCL c^aix 

CONNECTOR 




BOOT 
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-B 



CSR A00RES5 g 
17772150 = 
(AI-A6 IN) 



n 



n. 



n 



REF: SMDS0H23 



2.3.3 Media and CPU Type 

Each drive attached to the SDC-RQD11-SCH can be configured for operation with 
either removable or fixed media as shown in Figure 2-4. 
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Front Panel/RS-232 Maintenance Connector 



Installation 



The SDC-RQD11-SCH can be configured for operation with 1LSI-11 or MicroVAX 
II CPUs as shown in Figure 2-4. When using the SDC-RQD11-SCH in the 
MicroVAX II the CPU jumper can be configured as "LSI- 11" or "undefined," but 
not as "no CPU." 



Figure 2-4: 
Media and CPU 
Type 
Configurations 



riBDf 






MEDIA TYPE CONFIGURATION 
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REF SMD5CH24 



2.4 Front Panel/RS-232 Maintenance Connector 



Connector J4 can be used either to supply front panel signals to a user defined 
device, or to connect an ASCII terminal for maintenance purposes. 

2.4.1 Maintenance Terminal Adapter . 

The maintenance terminal adapter allows the controller to be connected to an 
ASCII terminal. It consists of a 10-pin flat cable with a DB25S connector on one 
end and a 10-pin insulation displacement type flat cable socket on the other. The 
communication format is: 

• ASCII RS232 

• 9600 Baud 

• 8 Data Bit 

• 1 Stop Bit 

• No parity. 

Note that if normal disk access is attempted with this cable connected to a terminal, 
garbage will appear on the terminal due to the shared RS232 Output/Access Light 
Function. This is normal. 
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Table 2-1: 
RS-232 
Maintenance 
Adapter Pinouts 



•PIN NUMBERS- 
J4 DB25S 



7 
8 
3 
4 



7 
2 
3 
7 



Function 

RS-232 Enable 

RS-232 Input 

*RS-232 Output 

Ground 



*From WOMBAT : +5V to -5V Compatible 



2.4.2 Front Panel Connections 

If required, a front panel can be connected to J4, the front panel/maintenance 
connector. The functions supported are listed in Table 2-2. 



Table 2-2: 
Front Panel 
Connector Pinouts 



PIN FRONT PANEL FUNCTION 

7 Drive 1 Write Protect Input. Connecting this input to Ground 
will write-protect the drive. Has an on-board 180 ohm pull-up. 

8 Drive Write Protect Input. Connecting this input to Ground 
will write-protect the drive. Has an on-board 180 ohm pull-up. 

1 Drive 1 On-line/Off-line Switch Input. Connecting this input to 

Ground will prevent access to the drive. Has an on-board 22k 
ohm pull-up. 

10 Drive On-line/Off-line Switch Input. Connecting this input to 

Ground will prevent access to the drive. Has an on- board 180 
ohm pull-up. 

3 Access Light. Indicating access to Drive 0, Drive 1 or Cache. 

This output can be used to drive an access light. The levels are: 

ACCESS:-5V through 1.5k ohm 

NO ACCESS: + 4.5 @ 20mA max. 

5 TTL signal indicating access to Drive 0. Low true. 

6 TTL signal indicating access to Drive 1. Low true. 
2,4,9 Ground 
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Drive Cabling Installation 



2.5 Drive Cabling 



The SDC-RQD11-SCH can simultaneously control two SMD drives which can be of 
different size, speed and data rate. Drive cabling is illustrated in Figure 2-5. Data 
cables are connected in radial fashion to edge connectors on the SDC-RQD11-SCH. 
The control cable is connected to drive and daisy chained between each drive (if a 
second drive is installed) with the last drive being terminated. 

Pre-configured data and control cable kits (Section 2-1) for one or two drives can be 
supplied to minimize difficulties when installing the SDC-RQD11-SCH or when 
adding additional drives. 



Figure 2-5: 
Drive Cabling 



Tn 



26-PIN DATA CABLE 




DRIVE 1 



DRIVE 



J3 »J1 J2 



_TL 



RjXNSJ = SINGLE DRIVE INSTALLATION 

'^'^^ (CABLE KIT P/N 501017) 

RSg&x:] +- En^JsJ] = DUAL DRIVE INSTALLATION 
i2220fl £^iXi (CABLE KIT P/N 501016) 

*J1 OR J2 CAN BE USED FOR EITHER DRIVE 



REF: SMDSCH2S 
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2.6 On-Board Bootstrap Operation (LSI-1 1 only) 



If the SDC-RQD11-SCH bootstrap is enabled the following occurs: 

1. Initialization code is loaded into host memory at location 2000. 

2. A "jump to 2000" instruction (JMP @ #2000) is loaded into location zero. 

3. The controller changes the contents of location 773002 to "CLR PC" and the fol- 
lowing message is typed:. 

BOOT V2.x (x = firmware revision level) 

4. The controller allows approximately 2 seconds for the operator to strike any key 
on the keyboard. If no key is struck the boot types: 

Booting from DUO: 

The boot then sets up registers and waits for that device's boot block to be read 
into memory starting at location zero. 

5. If any key is struck by the operator within two seconds the boot prompts with: 



The operator may then key in a device DU, DL, DY, MS or W. Note that 
device W will invoke WOMBAT. By further specifying A, B, or C after W, 
WOMBAT on controller A, B or C will be invoked. For example, WB will in- 
voke WOMBAT on controller B. 

The following is the syntax of the SDC-RQD11-SCH bootstrap procedure: 

[Device] [Controller Number] [Unit Number]: where: 

[Device] [Controller Number] [Unit Number] 



DU 


[A,B,C] 


[0-7]: 


DL 




[0-7]: 


DY 




[0-1]: 


W 


[A,B,C] 




MS 


[A,B,C,D] 





[ ] = options. If no options are specified, defaults = A, 0. 

Examples: DU1: for the second drive on the first DU controller 

DUB2: for a drive on the second DU controller 

DY1: for the second RX02 floppy disk drive. 

W: for WOMBAT 

WB: for WOMBAT on the second controller (B) 
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6. If any error occurs, a message from the following set is printed and the boot re- 
prompts for step five. 

"? - Device must be DU, DY.DL or MS" 

"Unit must be - 7" For DU or DL 

"Unit must be or 1" For DY 

"Controller must be A, B or C" For DL 

"Controller must be A, B, C or D" For MS 

"Boot failure" - Device unavailable (or not ready if DL) 

7. The controller reads the boot block, block zero, from the specified device into 
the host memory and then waits to be initialized. 

8. The host computer commences execution of the instructions in the boot block. 



Table 2-3: 
CSR Bootstrap 
Address 





DEVICE 


ADDRESS 




Console 


17777560 




DU: 


17772150 




DUA: 


17772150 




DUB: 


17760334 




DUC: 


17760354 




DUD: 


17760374 




DUE: 


17760414 




DUF: 


17760434 




MS: 


17772520 




MSA: 


17772520 




MSB: 


17772524 




MSC: 


17772530 




MSD: 


17772534 




DL: 


17774400 




DY: 


17777170 
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3. WOMBAT Utilities 



3.1 Starting Up WOMBAT 



WOMBAT provides a controller resident means of formatting, testing and maintain- 
ing the drive and controller subsystem. All WOMBAT functions are menu driven 
and are designed to simplify the process of structuring, formatting and testing drives. 

WOMBAT can be invoked using any of the following methods : 

• By selecting the 'W option during the system bootstrap operation if the 
SDC-RQD11-SCH boot is enabled. This allows disk testing and diagnostics 
to be performed from the user console. The console link is formed by a 
communication program which WOMBAT downloads into main memory. 

• By entering 250s (LSI-11) or 254s (MicroVAX II) from the console 
terminal using ODT. This allows disk testing and diagnostics to be 
performed from the user console. The console link is formed by a 
communication program which WOMBAT downloads into main memory. 

• By connecting a 9600 baud auxiliary terminal to the SDC-RQD11-SCH 
Maintenance Connector and entering 260s from the console terminal using 
ODT. This allows disk testing and diagnostics to be performed from an 
auxiliary terminal which communicates directly with on-board WOMBAT 
utilities. 

• By connecting a 9600 baud auxiliary terminal to the SDC-RQD11-SCH 
Maintenance Connector and configuring the switches on the PCB to 
automatically run WOMBAT. (CPU independent.) 

Runs WOMBAT independently of, or without, a CPU for controller testing 
or engineering purposes if necessary. First disable the controller bootstrap 
(Table 2-2) and set the CPU type to "No CPU" (Table 2-4). Connect a 9600 
baud terminal to the Front Panel connector and position the controller in 
the backplane. WOMBAT will be invoked automatically on power-up or by 
pressing reset. If no CPU is present then the backplane must be correctly 
terminated and a bus initialization signal (BINIT) must be generated. 
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To resume normal operation the configuration switches must be reset as 
required. Note that setting the CPU type to 3 will make the controller 
completely unavailable to the host CPU. 

• By depositing 272s into the IP register a user-written communication 
routine can communicate directly with WOMBAT. This call does not 
outload any communication routine into the host memory. 

Table 3-1 summarizes the procedures that invoke WOMBAT. 



Table 3-1: 
WOMBAT 
Initialization 
Procedures 



ACTION 


CONDITIONS 


CONTROL 


'octal 


*HEX 






000250 


00A8 


ODT 


LSI-11 Console 


000254 


00AC 


ODT 


Micro VAX Console 


000260 


00B0 


ODT 


Aux Terminal on Maintenance Connector 


000272 


O0BA 


ON-LINE 


User Communication Program 


W 




Via Boot 


System Console 


Boot Disabled 


CPU 


Aux Terminal on Maintenance Connector 


CPUTyp 


eO 


Independent 




These codes are deposited into the IP register (Section 4.6). 



The procedures for invoking WOMBAT on LSI-11, and the Micro VAX II are given 
below. WOMBAT can be stopped by simply re-booting the system. 

In each case input the appropriate CSR address for the controller to be accessed 
where indicated by 'CSR.' CSR octal addresses for the SDC-RQD11-SCH range 
from 17760334 to 17760720, with the standard address configuration at 17772150. 
Appendix A contains a complete CSR address list. 
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LSI-11 CPU 

The following details the procedure for invoking WOMBAT on an LSI-11 CPU sys- 
tem using console ODT. (Keyboard entries are bolded.) 



Halt the processor. 




'CSR'/ 


000000 


250 


R7/ 


xxxxxx 


2000 


RS/ 


000000 


340 


P 






MicroVAX II 







(ask WOMBAT to load the 
communications program) 
(set up the program start address) 
(set PSW to block interrupts) 
(now start the program without 



a bus reset.) 



The following details the procedure for invoking WOMBAT in a MicroVax II using 
ODT. 

Halt the CPU at the end of its start-up diagnostics by turning on the "halt enable" 
switch at the back of the CPU. 



When it halts : 




D/P/W 20001F40 


20 


D/L 20088008 


80000002 


D/W 'CSR' 


AC 



400 



(enable Q-bus access to memory) 
(set-up the appropriate Q-bus map entry) 
(ask WOMBAT to load the 
communications program into memory) 
(start the program) 



3.2 WOMBAT Menu Options 



When WOMBAT is invoked it will display an announcement and then print a list of 
all drives and units and prompts for the drive number on which to perform opera- 
tions. 

Enter the drive number (zero on a single-drive system). WOMBAT will then display 
the Master Menu options. 



SDC-RQDll-SC WOMBAT Version: 2.x 

(x is the firmware revision level.) 



UNIT DRIVE OFFSET SIZE 
34 20000 



WRITE STATUS 
LATE AVAIL 



DRIVE CYLS HEADS SECTORS BLOCKS ; MTYPE OPT FAIR STATUS 
1224 5 34 291312 FIXED NONE 24 SPUN UP 

Drive; number; 
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Select an option by typing the option number followed by RETURN. Options 1 
through 3 and 5 will provide sub menus while option 4 displays the last controller 
detected fatal error. To return to the master menu from a sub menu type RETURN. 

To exit from the master menu to the announcement (to select a different drive) type 
RETURN. WOMBAT will not allow you to do this before verifying whether the disk 
structure data has been written to disk. 'NO' is the default value. 



\ ** Master Menu ** 

1 Structure Disk 
|2 Test Disk 
; 3 Manage bad blocks 
; 4 Display error 

5 Shadow options 



3.3 Master Menu Options 



Option 1 - Structure Disk 

Selecting this option causes a sub menu to be displayed as follows: 




i ** Disk Structure Menu ** 

: 1 Create Disk Structure 

j 2 Format Disk 

;. 3 Write Disk Structure 

4 Update Header Blocks 

5 Display Disk Structure 
| 6 Change Unit number 

; 7 Display Statistics 
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Option 2 - Test Disk 

Selecting this option causes a sub menu to be displayed as follows: 



** Disk Test Menu** 

( ! means all data on Disk destroyed ) 

1 Read All Disk (preserves all data) 
2! Write Disk! 
3! Pattern Test ! 

4 j Random Writes ! 

5 ECC Validation 

6 Read Physical Block 

7 Display Error Statistics 

8 Zero Error Statistics 

9 Test Cache, RAM & ROM 



Option 3 - Manage Bad Blocks 

Selecting this option causes a sub menu to be displayed as follows: 



::** 



Bad Block Management Menu 



1 Manually Replace Bad Block 

2 Automatically Replace Bad Blocks 

3 Display Replaced Bad Blocks 

4 Enter defect map 



Option 4 - Display Error 

Selecting this option causes WOMBAT to display a message which explains the 
most recent controller detected fatal error. The occurrence of an error is indicated 
by the controller hanging with the red LED flashing. If no error has occurred this 
option produces a meaningless error message. 
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Option 5 ■ Shadow Options 

Selecting this option causes a sub menu to be displayed as follows: 



**$hadow options menu* 

1 Shadow copy option 

2 Set shadow units 

3 Reset shadow units 
i 4 6opy unit to unit 

5 Compare unit to unit 



Setting Up a New Disk 

The procedure for structuring a new disk is as follows: 

1. Create disk structure. 

2. Format the disk. 

3. Write the disk structure. 

4. Replace bad blocks using manufacturer's media defect map. 

5. Pattern test the disk. 

6. Replace bad blocks detected by pattern test. 

Once these 6 steps have been undertaken the host operating system may use the disk. 
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3.4 Disk Structure Menu Options 



** Disk Structure Menu ** 

1 Create Disk Structure 
2 Format Disk m.:' 

3 Write Disk Structure 

4 Update Header Blocks 

5 Display Disk Structure 

6 Change Unit number 

7 Display Statistics 



Option 1 - Create Disk Structure 

The Create Disk Structure option must be performed when a new disk is connected 
to the SDC-RQD11-SCH. This allows the various disk geometry, controller wide 
tuning parameters and virtual unit structure to be specified. The virtual unit struc- 
ture allows a single large drive appear to the host operating system as multiple 
drives. 

This option enters an interactive question and answer dialogue which specifies the 
disk structure. WOMBAT displays either the current or the default value for a 
parameter and gives you the option of accepting or changing it to a new value. To 
accept the displayed value, hit RETURN. To change it, type in the new value fol- 
lowed by RETURN. If WOMBAT detects improper values it will issue a warning. 

The create disk structure dialogue is divided into three parts. 

a. The drive structure specification, which describes the physical geometry of the 
drive. 



b. The unit structure specification, which is executed once for each virtual unit 
defined where the size of each unit and unit specific parameters is described. 



c. The controller wide tuning parameters, where read lookahead and command 
queue size are specified. 
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Drive Structure Specification 

Cylinders: Enter the number of cylinders the drive has. 



Heads: 



Enter the number of heads that the drive has. 



Full sectors/track: 



Short sectors/track: 



Track spiraling: 



Optimization: 



Compute and enter the required value described in sec- 
tion 3.12 - Computing Sectors Per Track. 

A short sector on each track will result if the number of 
full sectors does not completely fill a track. WOMBAT 
will render the sector invisible to the controller by writ- 
ing an illegal header on the sector. If the sector is too 
small WOMBAT will be unable to perform this opera- 
tion and errors will consistently occur during disk test- 
ing. In this case it will be necessary to reduce by one the 
number of sectors per track. 

Track spiraling improves disk performance on data 
transfers over more than one track. Sector zero on each 
track is offset by a nominated factor to allow head select 
and positioning before sector zero on the next track is 
reached. The recommended factor is four. 

The seek optimization strategy can be: 



(None) - No optimization done. First request found ex- 
ecuted. This may not be the next sequential request. 

1 (Nearest) - Selects request that is closest to the to the 
current cylinder. 

2 (Elevator) - Processes requests as it moves in one 
direction along the disk until it reaches the last request 
in that direction. This means that "Elevator" favors the 
center of the disk, as it passes it twice as often as the 
periphery. 

3 (Forward) - This processes requests from the lowest 
cylinder number to the highest in one direction only. 

Note that optimization is only effective if the host 
operating system supports multiple accesses. RT-11 and 
TSX plus do not support optimization without a special 
device handler. 
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Interface Type: 



Enter the correct value for the SMD interface type 
being used. It is possible to have a different SMD inter- 
face for each drive connected to the controller. The 
values are: 



- Standard 

1 - Modified 

2 - Enhanced 



Fairness count: 



3 - Extended 

The fairness count determines the number of times an 
I/O request will be passed over by the controller's seek 
optimization setting before it is executed. A reasonable 
count for normal use would be around 25. Every time a 
request is passed over its fairness count is decremented. 
When that count reaches zero that request will be 
selected, no matter what optimization strategy is in ef- 
fect. This count has no effect if no optimization is 
selected. 



This completes the drive structure specification. WOMBAT next prompts for a unit 
number. Type the unit number of the next unit to be defined, then hit RETURN. 
When the unit is completely defined, WOMBAT will again prompt for a unit num- 
ber. If there are no more units to define hit RETURN. WOMBAT will then 
proceed to the controller wide parameter definition. Note that if no units are 
defined, the operating system will not see anything attached to the controller. 



Unit Structure Specification 



Unit Number: 



Unit size: 



Media type: 



WOMBAT next prompts for a unit number, which al- 
lows the user to define the unit size for partitioning into 
logical units. If the default unit size is used, one logical 
unit is defined. The options for "Unit Number" follow: 

If an existing unit number is specified WOMBAT will 
display the size in blocks. If a new unit number is 
specified WOMBAT will display the size in blocks of 
the first unallocated disk area it finds beginning at the 
start of the disk. On a new disk this will be the entire 
user area. This can be changed to a smaller value if 
necessary. To delete an existing unit, specify zero for 
this field. 

This field is displayed by some operating systems when 
you inquire about the type of drive. As a part of unit 
status when a "Get Unit Status" command is issued the 
MSCP protocol returns a 5 character media type 
(default is DURA81). The first two characters must be 
'DU'- for example - DURD54. To change this enter 1 to 
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5 alphabetic characters and 2 digits, e.g. RD52, to emu- 
late DECs 31 megabyte Winchester. For example, RSX- 
11M-PLUS responds to a "DEV DU:" command with : 
"DUO: Public Mounted Loaded Label 
RSX11MPBL15 Type = RA81." 

Serial number: The MSCP protocol returns a 32-bit volume serial num- 

ber as a part of its response when an "on-line" command 
is issued. WOMBAT defaults this field to zero. To 
change this enter the desired serial number. This field is 
used, for example, by RSX-11M-PLUS, when a disk is 
initialized with the "INI DU:" command. It sets up the 
volume serial number. 

Host Write Confirm; This specifies if the controller is to notify the host that a 

write request has been completed. Enter 1 if the host is 
to be notified when the data is in the cache. The data 
will be written to the disk later. Enter 2 if the host is to 
be notified when the data has actually been written to 
the disk. 



This completes the unit structure definition. Now WOMBAT enters the final part of 
the dialogue which specifies the controller wide tuning parameters. 

Controller Wide Tuning Parameters 

Read Lookahead: 

This is a feature of the cache which allows the controller to read a specified number 
of sectors in addition to those requested by the host. Enter the minimum number of 
blocks you wish the controller to read for any request. For example if a value of 4 is 
specified, when the host asks for a single block to be read, the next 3 blocks will 
automatically be read into the cache. If the host subsequently asks for one of these 3 
blocks then the request can be honored immediately from cache. If the host requests 
a transfer equal to or larger than the read lookahead size then this parameter will 
have no effect. 

Cache Enable: 

This parameter enables or disables the cache. A value of disables the cache and a 
value of 1 enables the cache. The cache cannot be selectively enabled or disabled 
for a particular drive or unit number. 

Command queue: 

This parameter allows you to specify the number of commands the controller can 
stack. The controller will then attempt to optimize the order in which they are ex- 
ecuted. Large command queue stacks incur considerable overhead and will degrade 
controller performance. Note also that some operating systems (RSX-llM-Plus 2.1B 
is a good example) have a maximum limit for the size of the stack. The default size 
[8.] is a good compromise and is acceptable to most operating systems. 



SDC-RQD11-SCH Manual REV A MA400995 Sigma Information Systems 



WOMBAT Utilities Di^S^ctoeMenu.p^tiom ?7. 



Front Panel Type: This option allows the correct selection of front panel 

type. This option is normally set to "1." See Section 2.4.2 
- Front Panel Connector. 

- None 

1 - Passive 



This completes the disk structure definition. WOMBAT now checks the tables for 
consistency and returns to the disk structure menu. 

Option 2 - Format Disk 

WOMBAT asks you to confirm this drastic action as it will destroy ALL data that 
resides on the disk. WOMBAT will then initiate a two pass formatting operation. 
During the first pass WOMBAT creates all the sectors on the disk, write a sector 
headers which contain the sector number, the head number, and the cylinder num- 
ber, as well as preambles and sync bytes, followed by a 2 byte data field. During the 
second pass WOMBAT writes a test pattern to each sector, preparing the disk for 
read testing. WOMBAT then writes the disk structure onto the reserved areas. 

Option 3 ■ Write Disk Structure 

WOMBAT will ask you to confirm this drastic action as any existing disk structure 
will be destroyed. WOMBAT will then write the new structure onto special reserved 
areas of track zero. The data is recorded twice for improved recoverability. A total 
of 6 blocks is written on track zero. After the structure has been written, the drive's 
replacement block table is zeroed. If there were any replaced blocks recorded there, 
they will be lost. However they will still be marked as replaced and will generate 
hard errors during a read operation. 

Option 4 - Update Header Blocks 

This is similar to Write disk structure except that the replacement block table is not 
written, thus preserving any blocks which may have been replaced. This option is 
used after changes to the disk structure such as changing unit numbers or redefining 
the virtual units. Unless the header blocks have been updated, the changes are not 
recorded on disk. 

Option 5 - Display Disk Structure 

WOMBAT displays the structure of the currently selected drive in a form similar to 
the create disk structure dialogue. This is useful for checking that the newly created 
structure is correct. 

Option 6 - Change Unit Number 

It is sometimes necessary to change a unit number in order to resolve a duplicate 
unit number or to satisfy operating system requirements. This method is a safe and 
simple way of doing so. WOMBAT prompts for a unit number on the current drive, 
and then for the new number for that unit. NOTE: For the change to take effect, the 
header blocks must be updated using option 4 above. 
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Display Statistics 

Statistics about disk and cache usage are maintained, and recorded on the disk peri- 
odically. They are displayed as: 



Controller statistics report 
# of commands ' ; ; : : xxxx 

# of reads ; xxxx # of cache hits xxxx (xxx%) 

# of writes i xxxx 

thrive statistics report 

Drive #.'":! Soft errors Re-vectors Blocks replaced 

xxx '"' :'.;... xxxx. ...... xxxx xxxx 

Drive # '. Seek distance # of seeks Seek errors 



xxx 



xxxx 



xxxx 



xxxx 



Commands is the number of MSCP commands issued. 

Re-vectors is the number of accesses to replaced blocks. 

Seek distance is the total seek distance, in cylinders. 

Blocks replaced is the number of blocks dynamically replaced by the controller 
during normal operation, rather than through WOMBAT. 

Reset Counters is then asked. "Y" will reset them to zero. 



3.5 Disk Test Menu Options 

— 1«— mil iwiiwimiiwwimiiiiiiiiwiiii'iimimwiiiiiiiiiiiihiiiiiii ii innnmr 'iinr ii ii ■ « I ii ■rninrmiwr aw wdmaa 



A disk can be tested after it has been formatted and before the structure is written 
to it. Testing does not overwrite the HDR or RCT blocks. The disk structure must 
be written to the disk before bad blocks can be replaced. 

All tests continue indefinitely until aborted by one of the following methods: 

1. If an RS232 serial port terminal is attached to the controller, press BREAK. 

2. If WOMBAT is running from the Console terminal, type CTRL/C. 

When a test is aborted the Test Disk Menu options are returned. If tests are run 
from an RS232 terminal attached to the controller, beware of system activity on the 
host computer as Q-bus initializations will cause the disk controller firmware to re- 
initialize and so leave WOMBAT. 

All tests give 10 retries on an error, reporting every error by displaying the block 
number and an error code. 
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: * * Disk Test Menu * * 
( ! means all data on Disk destroyed) 

1 Read All Disk (preserves all data) 
2TWritebisk! 
3 ! Pattern Test ! 
4 ! Random Writes '! 

5 ECC Validation 

6 Read Physical Block 

7 Display Error Statistics 

8 Zero Error Statistics 

9 Test Cache, RAM & ROM 



Option 1 - Read All Disk 

This test reports any read errors. Successful operation will be reported in the follow- 
ing format: 



Pass: 1. Errors: 0. 
Pass: 2. Errors: 0. 



This function does not destroy any information. 
Option 2 ■ Write Disk 

This test reports any write errors while writing a test pattern to the whole disk. 
ALL INFORMATION on the disk, excepting HDR and RCT blocks, is 
DESTROYED. Errors are displayed in the standard format: 



Block: 32040 (Error message) 
Pass:l. Errors: 1. 
Pass:2. Errors: 1. 



The displayed error count is cumulative until the test is terminated. 
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Option 3 - Pattern Test 

A test pattern is written to each block, including the replacement blocks. WOM- 
BAT does one write and 10 read passes. This test reports any errors in the standard 
format as shown above. 

Option 4 - Random Writes 

This test writes 5000 blocks at random locations in the user area of the disk. It then 
reads the entire disk to determine if any of the writes caused an error. This test is 
designed to test the head positioning and selecting logic of the drive. 

Option 5 - ECC Validation 

The ECC test uses a special reserved block on track zero for testing. It first proves 
that it can successfullycorrect an 11 bit error and then proves that it cannotcorrect a 
12 bit error. This test checks the ECC logic within the SDC-RQD11-SCH. 

Option 6 - Read Physical Block 

WOMBAT prompts for a block number anywhere on the disk. It then converts that 
block number into a physical address consisting of cylinder, head, and sector, and 
displays these values in hex and ASCII. Then it reads that sector and displays a mes- 
sageindicating the success or failure of the read. The same physical block can be re- 
read by typing \ instead of a block number. The block's replacement block can be 
read by typing @. 

Option 7 - Display Error Statistics 

Displays the error statistics gathered by any of the above disk testing options in the 
following format: 















1 Error St atistic 

Block ■■;■■'■,'■'■'■'■■■■'■■'■'-■ 


S ' 

Number (of ei 


ror:;) 




; 132040 : 


1. 




; Blocks in error: 


1. 






:■:■ ■:■'..■::.'■ : : : ■: •: : : . - : -■ r .-' -.-. : -: : :-.•:■..:.:..:- 











Option 8 - Zero Error Statistics 

Zeroes the error statistics table and redisplays Test Menu options. 
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Option 9 ■ Test Cache, RAM & ROM Option 

This test continuously writes test patterns throughout the entire cache and reads 
them back testing for veracity. A separate part of the test automatically checks that 
the parity logic is functioning correctly by forcing incorrect parity and checking that 
an error occurred. The cache pattern tests use special microcode instructions which 
iteratively read and write large blocks of cache memory at high speed. The Static 
RAM is also tested and the code PROM is Checksummed. 

3.6 Bad Block Management Menu Options 



** Bad Block Management Menu ** 

1 Manually Replace Bad Block 

2 Automatically Replace Bad Blocks 

3 Display Replaced Bad Blocks 

4 Enter defect map 

5 Get defect map from drive 



Option 1 - Manually Replace Bad Blocks 

WOMBAT prompts for a block number within the user areaof the disk. Then it 
marks the specified block as bad and allocates a replacement block for it. 

Option 2 - Automatically Replace Bad Blocks 

WOMBAT searches the error statistics table, which is compiled by the read, write, 
and pattern tests, for blockswhose error count exceeds three. Any such blocks are 
marked asbad on the disk and replacement blocks are allocated for them. 

Option 3 - Display Replaced Bad Blocks 

WOMBAT reads the Replacement Control Table and displays the logical block 
numbers of any blocks recorded there. 
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Option 4 - Enter Defect Map 

This option prompts for the drive manufacturer's defect map information as follows : 
Enter defect map for drive n 
(Enter all values as decimal!!!) 
CTRL-C to exit at any time. 
RETURN to back up 1 prompt. 

Bytes per sector: The number of bytes per sector as set up in the drive 

switches (hard sector drives), or calculated by following 
the procedure in section 3.12 Computing Sectors per 
Track. 

Cylinder: Cylinder number of defect. 

Head: Head number of defect. 

Bytes past index: Location past index of defect. 

Bit length of defect: Length of defect in BITS. 

This data is then used to compute the address of a block on the disk. If it does not 
match a block on the specified disk track the error message "!! Beyond last sector" is 
produced. This may mean that the defect is located beyond the last data sector on 
the track, or that the entered data was wrong. WOMBAT then calculates the block 
number, displays it and replaces it. The "Cylinder:" prompt is then repeated. 

3.7 Shadow Options Menu Option _ __ 



This feature shadows, i.e. keeps two copies, of a 'logical unit.' When the disk control- 
ler and drives are first powered up, any unit (and a physical disk may be broken up 
into a number of 'logical units') that is shadowed has its contents copied to its 
shadow unit. Thereafter any update of that unit will cause the controller to update 
the shadow unit as well. When reading from a shadowed unit, the drive with its 
heads nearest the required data is used. This helps to keep the drive shadowing over- 
head down, although in normal circumstances, with writes consisting about 10% of 
reads, there is a performance penalty. 

Shadowing consists of two operations: the initial copy of the entire primary unit to 
the shadow unit; and then the updating of both primary and shadow units on every 
disk write. Updating of both copies takes place as a matter of course, while the ini- 
tial copying can happen at various times depending on the 'Shadow copy option' 
selected. 

The main reason for drive shadowing is RELIABILITY. When reading, any error 
detected will cause the controller to use the data on the other drive. This means 
that, besides the controller having extensive error recovery facilities, there is a redun- 
dant backup of all data on the shadowed unit without any user programming or 
operating system overhead. 
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Drive shadowing is completely controlled from the 'Shadow options' menu. 



**Shadow options menu** 

1 Shadow copy option 

2 Set shadow units 

3 jRcset shadow units 

4 Copy unit to unit 

5 Compare unit to unit 



Option 1 ■ Shadow Copy Options 

The first step is to select how the unit (the 'Primary unit') is to be copied to its 
'Shadow unit.' There are 4 options: 



■ WOMBAT Only 



1 - On power up 



2 ■ Not ready/ready 



3 - Power up or Not 
Ready/ready 



This is the default. With this selected the primary is only 
copied to its shadow when you invoke it in the Copy 
Unit to Unit option. 

This causes the copying to be done whenever the 
drive(s) are first powered up, or WOMBAT has been in- 
voked. 

The copying is to be done whenever the controller 
detects the shadow unit going from a not ready to ready 
condition - e.g. a removable drive being bought on-line. 

A combination of 1 and 2 above. 



The use of copy type only is recommended at this time. It is considered that the 
other options have too high a probability of copying bad data from the primary unit 
over good backup data on the shadow unit. 

Option 2 - Set Shadow Units 

Shadow units are logically connected to primary units by this option which asks: 
Primary unit: The unit to be shadowed. 



Shadow unit: 



The unit number of the shadow. 



The shadow unit will not be available to any operating system as it appears as 'unit 
undefined'. It must be EXACTLY the same size as the primary unit. 
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Now copy the primary to its shadow by using the Copy unit to unit option. 

You may shadow a unit on the same physical drive, though you lose both reliability, 
by having the data on only one drive, and performance, by having the disk heads 
move to write all data twice. 

If you have selected a shadow copy type of 1 or 3, whenever the controller is 
powered up and its first 'MSCP Initialize' sequence executed for the primary unit 
(the unit you wanted shadowed), the contents of this unit are copied to its shadow, 
or if WOMBAT has been invoked. The time this takes obviously depends upon the 
number of blocks on the unit, but we have found that a third of a megabyte per 
second is a good guide. While this is happening user I/O may take place, but will be 
made slower by the 'shadow copy 5 taking place. 

WARNING: A potentially serious problem exists with the automatic copy of data 
from the primary to the shadow at power up (shadow copy types 1 or 3). If the 
primary has been corrupted, or the data is invalid, IT WILL DESTROY YOUR 
BACKUP. If you have trouble with your primary unit use WOMBAT to change it 
from a shadow primary. You may even want to change its unit number via the 
'Change Unit number' option, and then bring in the shadow unit as its replacement. 
Please realize that the controller MUST assume the validity of the primary unit at 
the first initialization after power up if you have selected one of the power up copy 
types. 

Option 3 - Reset shadow units 

This option allows disabling of an assigned shadow unit: 

Primary unit: The primary unit. 



Shadow unit: The unit number of the shadow to be disconnected from 

the primary. 



This shadow unit will now be available to the operating system. 

Option 4 - Copy Unit To Unit 

To copy a primary unit to its shadow: 

Primary unit: The number of the unit you want copied. 

Shadow unit: The unit you want the data copied to. 

The copy will take place. Data is transferred at about twenty megabytes a minute. 

Option 5 - Compare Unit to Unit 

This option allows the comparison of the data on a primary and a shadow unit: 

Primary unit: One of the units. 
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Shadow unit: The other. 

If any data errors, or data compare mismatch, is found, the block number and type 
of error will be reported. The comparison proceeds at about two megabytes a 
minute. 



3.8 WOMBAT Disk Structure 



WOMBAT records the logical structure of the drive on track 0. All of track is 
reserved for this and other testing purposes. The user area begins at the next block 
after track 0. This is the same as the number of sectors per track. The user area ex- 
tends to the block before the beginning of the Replacement Control Table (RCT). 
The size of the RCT is fixed and is always 2 tracks. The 2 tracks are accessed by dif- 
ferent heads and contain identical data. All the blocks from the end of the second 
RCT track to the end of the media are reserved for replacement blocks. 

The disk area reserved for RCT and replacement blocks is always an integral num- 
ber of cylinders. The number of cylinders required is always computed from the 
total number of cylinders on the drive. This reserves a constant proportion of the 
media for replacement blocks. The amount reserved is approximately 0.1% of the 
total formatted capacity. Option 4 of the master menu will report the formatted 
capacity of each drive. You can determine the user area easily. It will be reported as 
the size of the first unit configured on that drive. If there is more than 1 unit, then 
the sum of their sizes is the total user area, assuming there are no unallocated areas 
on the disk. 

All block numbers in WOMBAT are physical block numbers beginning at the first 
sector of the first head of the first cylinder of the drive, which is defined as block 
zero. The last block on the drive is block n-1 where n is the total number of blocks 
on the drive. Therefore, the first block of the user area is not block zero. Its block 
number is the same as the number of sectors per track, as track on the drive is 
reserved. Option 4 of the master menu will display both the size and the offset (start- 
ing block number) of each unit defined. Using these figures you can determine the 
exact position and extent of any unit. 



3.9 Drives with Removable Media 



Some manufacturers offer drives with removable media. The SDC-RQD11-SCH 
detects when such a drive is connected and makes certain changes to the way it 
operates. The important changes are that you can only have one virtual unit on a 
drive whose media can be removed. That unit must have the same unit number as 
the physical drive number. The reason for this is that it is necessary to determine the 
unit number even though the media may be removed. This means that the unit num- 
ber cannot be recorded on the media for these drives. WOMBAT automatically 
detects these drives and prevents you from creating incorrect units on them. 
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3.10 Error Recovery Procedures 

During normal operation, the SDC-RQD11-SCH checks every disk transfer for er- 
rors. When an i/o error is detected, the SDC-RQD11-SCH enters a special error 
recovery procedure to attempt to provide the host with 'perfect' media. 

The first method used to recover the data is simply to try the operation again. If this 
succeeds, the host is guaranteed to receive good data. This is repeated until a 
threshold is reached, at which time the second error recovery procedure is initiated. 
The second procedure recalibrates the drive and reseeks to the block in error in an 
attempt to correct any positioner errors that may have prevented data recovery. 
After the reseek, the operation is again retried until the retry threshold is reached. 
If any of these retries succeeds then the host is guaranteed good data. If the retry 
threshold is reached after reseeking, then the final error recovery procedure is at- 
tempted. This procedure is ECC. The ECC bits appended to each block are used in 
an attempt to correct the error. If successful, the host is guaranteed good data. 

If the data is successfully recovered by retrying, then the number of retries necessary 
is checked. If it exceeds the retry soft error limit then that block is dynamically 
replaced, on the assumption that it is in the process of gradual failure and will get 
worse. The known good data is written to the replacement block and the host is 
notified of success. 

If the data is successfully recovered by the ECC algorithm then the block is dynami- 
cally replaced on the assumption that the block has developed a hard error. The cor- 
rected data is written to the replacement block and the host is notified of success. 

If the data cannot be recovered by any of these means then the block is assumed to 
be bad. The block is dynamically replaced, and is written with forced error status. 
This will cause forced error status to be returned whenever the block is read, telling 
the host that while the block is good, the data in the block is bad. When the block is 
written, the forced error status will be removed and from then on the block will be 
good. When a block is dynamically replaced with forced error status, the host is 
notified of a forced error on that block. 



3.1 1 Drive sha dowing 



This feature provides continuous automatic backup of important data. The normal 
case is to have two identical drives with a single unit on each. The primary unit must 
be of identical size to the shadow. Once the primary/shadow pair has been defined, 
the shadow unit will become invisible to the host. All writes directed to the primary 
will also be written to the shadow. If a read is directed to the primary, the controller 
will attempt to redirect that read to whichever drive of the pair has its heads posi- 
tioned closest to the requested data. 

This feature only offers protection against the primary unit failing. It cannot protect, 
as a normal backup can, against a rogue program which writes garbage on the disk. 
The garbage will simply be copied onto the shadow unit as well. It is advisable, al- 
though not mandatory, that the shadow unit is on a different drive to the primary if 
the maximum protection is to be gained. 



SDC-RQD11-SCH Manual REV A MA400995 Sigma Information Systems 



WOMBAT Utilities .........................Compu^ ?7 



Data can be recovered from the shadow if the primary fails by running WOMBAT. 
Disable the shadow unit with the "Reset shadow units" option of the Shadow Op- 
tions Menu. Then (optionally) change the unit numbers of the two units with the 
"Change unit number" option of the Disk Structure Menu. Once the data has been 
recovered the primary unit can be serviced and re-installed in the system. 

3.12 Compute Sectors Per Track 



To compute the number of sectors per track first determine the number of bytes per 
track from the drive manual. Divide this figure by the number of bytes per sector. 
The controller requires at least 595 bytes per sector. The drive switches should be 
set to provide the appropriate number of sectors per track. In some cases this will 
result in a short sector at the end of the track. If the drive has a short sector WOM- 
BAT must be told when structuring the disk. 

For example the number of full sectors per track for a PRIAM 806 Winchester with 
an SMD interface would be calculated as follows: 

The unformatted capacity per track is 20,160 bytes. This is divided by 595 giving the 
number of sectors per track. 

20,160 

= 33.882 sectors per track 

595 

In this case there will be 33 full sectors with one short sector. 

For a CDC 9715 Winchester, the unformatted capacity of each track is 30,240 bytes. 

30,240 
= 50.824 sectors per track 

595 
In this case there will be 50 full sectors with one short sector. 

3.13 WOMBAT Error Messages 



The following is a list of the error messages displayed by WOMBAT. 

sector not found Indicates that the sector asked does not exist or cannot 

be located. 

drive fault Indicates that the drive is faulty and that service is neces- 

sary. 

drive timed out Indicates that the drive has failed to complete an opera- 

tion. 

data field error Indicates that bad data exists in a sector. 
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controller fault 



Indicates controller failure. Service will be necessary. 



block marked as bad 



data late 



forced error 



Indicates that the block has been flagged as bad. The 
controller will refer to the RCT for a replacement block. 

Data is lost due to internal overflow in controller 
memory before transmission over the bus to host. 

A forced error occurs when a good block has bad data. 
The block is flagged forced error until good data is writ- 
ten to the block. 



seek error 



An error has occurred on a seek operation. 



ret full 



The replacement control table is full. An error of this 
kind indicates that the disk has too many errors to be 
serviceable. 



ret read error 



Fatal error which indicates the controller cannot read 
the RCT. 



ret write error 



Fatal error which indicates the controller cannot write 
the location of replacement blocks. 



illegal sector specified A sector with an illegal number has been specified. 



illegal block number A block with an illegal number has been specified. 



nonexistent drive 



A drive has been specified which does not exist. 



unit table full 



The unit table is full. The maximum number of units is 
16. To create a new unit an existing unit must be un- 
defined. 



no drive selected 



non-existent unit 



A drive must be selected before WOMBAT can per- 
form any operation. Select any valid drive. 

The unit selected has not been defined. 



disk structure write error WOMBAT is unable to write the structure to the disk. 

This is a fatal error indicating that the drive is not serv- 
iceable. 
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3.14 WOMBAT Self-Diagnostics 



Initialization procedures 

A common initialization procedure exists for both WOMBAT and the MSCP 
firmware. It performs: 

a RAM integrity test 

a ROM checksum 

various checks on the disk drive and its structure 

The errors which can result from this are described under Section 4.9, Fatal Con- 
troller Errors. 
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4. MSCP Programming 



4.1 Overview of MSCP 



Mass storage control protocol (MSCP) is a message-oriented set of rules by which 
the SDC-RQD11-SCH controller module and the host system communicate. This 
protocol allows the host to send message requests for data reads or writes to the 
controller and receive response messages back from the controller. The host does 
not concern itself with details such as device type, media geometry, media format, or 
error recovery. 

All software and hardware functions are partitioned into independent 'host' and 
'controller' layers. Each layer consists of a high-level I/O driver and a 
communications server. The controller layer receives and processes commands 
which have been formed by the host layer. 

The communications server handles all communications protocol between the I/O 
layers, leaving the I/O system free to process data requests. Communications 
between host and controller are carried out on the I/O bus without having to 
generate processor interrupts. The host's communications server monitors all 
command transmission and response and in the event of failure or error, initiates 
recovery procedures. 

Disk drive parameters are transparent to both the host and controller resident layers 
of MSCP. The disk drive passes factors such as disk geometry, storage capacity or 
error retry counts to the disk controller on system start-up. 

In addition to relieving the host of disk-specific data, the disk controller and disk 
provide the host with "clean" data. The disk drive handles some positioner errors 
entirely by itself but performs certain error-recovery operations under direction of 
the disk controller. 



4.2 Controller Communications 



The host designates an area of memory to be used as a communications area 
between itself and the controller. This area is made up of two sections a header area 
containing interrupt identification words and a variable-length section containing the 
response (receive) and command (send) lists, organized into ring buffers. Figure 4-1 
shows the memory communications format. 
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Figure 4-1: 
Memory 

Communications 
Format 
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Command and Response Rings 

Command and response lists are organized into 'rings' of 32 bit descriptors. The 
length of each ring is determined by the speed with which the host and controller 
generate and process messages. The host sets the ring lengths at initialization time. 
Figure 4-2 describes the Descriptor Format while Table 4-1 details the code 
descriptions. 



Figure 4-2: 
Descriptor Format 
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Table 4-1: 
Command Ring 
Code Descriptions 



CODE DESCRIPTION 

Z Is zero, as envelope address (text + 0) is word-aligned. The controller 

will always assume that Bit 00 is set to zero. 
L Low-order envelope address. 

H High-order envelope address. 

F Flag bit. 
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When the controller returns ownership to the host it sets F = 1 to indicate that it has 
completed action on the descriptor. 

When the controller acquires ownership of a descriptor from the host, F = l 
indicates that the host is requesting a ring transition interrupt. If F = 0, the host is 
not requesting a ring transition interrupt. An interrupt will occur only if this 
descriptor causes a ring transition and if transition interrupts were enabled during 
initialization. 

The controller always sets F=l when returning a descriptor to the host, so if a host 
wishes to override ring transition interrupts it must always clear F when passing 
ownership of a descriptor to the controller. 

O Ownership bit. Set to if owned by the host or 1 if owned by the controller. 
Interlocks the descriptor against premature access by either party. 

Message Packets 

The command or response descriptor points to word (text + 0) of a 16-bit 
word-aligned message envelope formatted as shown in Figure 4-3. Table 4-2 
describes the word envelope contents. 



Figure 4-3: 
Message 
Envelope Format 
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Table 4-2: 
Word Envelope 
Contents 



WORD 





ENVELOPE CONTENTS 

Message length, in bytes. 

For commands, this length is equal to the size of the 
command (in bytes), beginning with [text + 0]. 

For responses, the host sets the length equal to the size 
of the response buffer (in bytes), beginning with 
<text+0>. Before actual transmission of a response, 
the controller reads the field length in the message en- 
velope. If the controller's response is longer than the 
response buffer, the controller will fragment its 
response into as many response buffers as necessary. 

The controller sets the resulting value into the message 
length field. The host must therefore keep re-initializ- 
ing the value of this field for each proposed response. 
If a controller's responses are less than or equal to 60 
bytes, then the controller need not check the size of the 
response slot. 

Connection Id. Identifies the connection serving as a 
source of, or destination for, the message in question. 

Message Type. The following response ring message 
types are implemented: 



MSGMNT Maintenance packet (diagnostic) 

MSGCRD Credit notice (ignored) 

MSGDAT Datagram packet. 

MSGSEQ Sequential packet 

Credit field. Gives a credit value (usually one) as- 
sociated with the message. This mask, in response pack- 
ets, is added to the controller's credit field to give the 
number of commands-in- progress. So while Word 1 is 
always 1 for the command ring, this is not the case for 
response rings. 
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4.3 Message Transmission 



Command Transmission 

When the ownership bit (O) of a command ring descriptor is equal to 1, it means 
that the host has filled the descriptor and is releasing it to the controller. When the 
ownership bit (O) resets to zero, it means that the controller has emptied the 
command ring descriptor and is returning ownership of the descriptor to the host. 

To ensure that the controller sees every command, the host must read the IP 
register whenever it inserts a command in the command ring. This forces the 
controller to poll the command if it was not already accessing the command ring. 

Response Transmission 

When the ownership bit (O) of a response ring descriptor is equal to zero, it means 
that the controller has filled the descriptor and is releasing it to the host. When the 
ownership bit (O) sets to 1 it means that the host has emptied the response ring 
descriptor and is returning ownership of the descriptor to the controller. Just as the 
controller must poll for commands, so must the host poll for responses. 

Interrupts 

The transmission of a message will result in a host interrupt from the controller 
under the following circumstances. 

1. During the initialization process (open a 'connection'). 

2. When the command ring buffer transitions from 'full' to 'not full.' This interrupt 
means that the host may place another command in the command ring. 

3. When the response ring buffer transitions from 'empty' to 'not empty.' This in- 
terrupt means that there is a response for the host to process. 

4. When a fatal controller error is detected and an interrupt can be generated. 
These are: 

Failure to become Q-bus master for data transfer 
Failure to become Q-bus master for interrupt 
Failure to access I/O page registers or communication area 
Q-bus parity error detected. 



4.4 Data Transmission 



In the command ring, the descriptor points to a command packet. Within the 
command packet is a buffer descriptor which contains a pointer and a byte or word 
count. The buffer descriptor points to the data buffer which holds data transfers. 
The data is moved by the controller into or out of the buffer as DMA transfers 
to/from Q-bus addresses. 
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4.5 Initialization 



The purpose of initialization is to identify the parameters of the host-resident 
communications region to the controller, provide a confidence check of controller 
integrity, and bring the controller on-line to the host. 

Initialization Process 

This paragraph describes the activity within the SA register during an initialization 
process. This is dependent on whether SA is being read or written. 

By moving 4000 into IP, the controller initializes and passes back the 'step' response 
in SA. Then, the initialization parameters are written into SA. There are 4 words of 
initialization, and the controller must reflect each step by the appropriate step 
response, which is also returned in SA. The initialization parameters are set out 
below in Table 4-3. 



Table 4-3: 

Initialization 

Parameters 



WORD 





CONTENTS 

Command and Response ring sizes, interrupt enable 
and vector. The host writes into SA the lengths of the 
rings, whether interrupts are to be armed, and if so, the 
address of the interrupt vector. The controller then 
runs a complete internal integrity check and signals 
either success or failure. 

Low order address of communications area, i.e., ring 
buffer address. The host reads an echo of the ring 
lengths from SA, and then writes into SA the low-order 
portion of the ring base address. 

High order address of communications area, bits 0-14. 
The interrupt vector address and the master interrupt 
arming signal are echoed in SA. The host then writes 
the high order portion of the ring base address to SA 
along with a signal that conditionally triggers an im- 
mediate test of the polling functions of the controller. 

Burst transfer control, last failure flag, and the 'GO' 
bit. The controller tests the ability of the Q-bus to per- 
form DMA transfers. If successful, the controller 
zeroes the entire communications area, and then sig- 
nals the host that initialization is complete. 
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4.6 Registers 



The programmable registers contained on the SDC-RQD11-SCH are the Initialize 
and Poll register (IP) and the Status and Address register (SA). 

Initialize and Poll Register (IP) 

The host begins the initialization sequence by either issuing a bus initialize or by 
using the IP initialize operation. Any write to that address will cause an initialization 
of the controller. When read while the controller is operating, it causes the 
controller to initiate polling. The SDC-RQD11-SCH responds to the 16 bit 
initialization words as set out in Table 4-4. 



Table 4-4: 










Initialization Words 


NUMBER 


FUNCTION 


PROCESSOR 




OCTAL 


HEX 








000250 


00A8 


WOMBAT 


PDP/11 




000254 


OOAC 


WOMBAT 


MicroVAX II 




000260 


00B0 


WOMBAT 


On board maintenance port 




000272 


00BA 


WOMBAT 


User communication program 



Status and Address Register (SA) 

The SA register consists of a set of two registers, the SA read register and the SA 
write register. 

When read by the host during initialization, it communicates data and error 
information relating to the initialization process. When written by the host during 
initialization, it communicates certain host-specific parameters to the controller. 

When read by the host during normal operation, it communicates status information 
including fatal errors detected by the controller. 
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4.7 MSCP Commands 



Table 4-5: 

MSCP Commands 



COMMAND 

Access 
Abort 

Available 

Compare Host Data 

Erase 

Get Command Status 

Get Unit Status 
On Line 
Read 



Set Controller 
Characteristics 

Set Unit 
Characteristics 

Write 



FUNCTION 

Reads data from the specified unit. 

Guarantees that referenced MSCP command will com- 
plete within the controller time-out period. 

If specified unit is on-line, returns it to the unit-avail- 
able state. If specified unit is currently in the unit-avail- 
able state, this command has no affect. 

Reads data from the disk and compares it with the 
data in the host buffer. 

Writes zeros to the specified logical blocks on the unit. 
(No data is accessed from the host). 

Reports on the status of a specified command by 
returning a number that reflects the command's 
progress. 

Reports on the status of a specified unit. 

Places the specified unit on line, if possible. 

Reads data starting from the specified logical block on 
the disk, into host memory. 

Sets host-settable controller characteristics. 
Sets host-settable unit characteristics. 



Writes data starting at the specified logical block on 
the disk, from the host memory. 
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4.8 Error Handling 



High data integrity is achieved by the controller through a 48 bit ECC (error 
checking and correction) polynomial with an 11 bit correction span. ECC will first 
try to read or write a block up to 10 times before attempting to correct the error. If 
error correction fails a non-recoverable error is reported. Table 4-7 details the 
MSCP status code messages. 



4.9 Fatal Controller Error 



If a fatal error is detected when the controller is initialized, the red error LED 
flashes and the fatal error status is set in the SA register. Table 4-6 describes fatal 
controller errors. 

Running WOMBAT and selecting the Display Error option will give an appropriate 
error message. A full description may be found under Section 3.17 - WOMBAT 
ERROR messages. 



Table 4-6: 








Fatal Controller 
Errors 


ERROR 




DESCRIPTION 




OCTAL 


HEX 






100004 


8004 


RAM test failure 




100005 


8005 


ROM checksum failure 




100011 


8009 


No drive 




100100 


8040 


Disk unformatted 




100101 


8041 


Disk unstructured 
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Table 4-7: 
MSCP Status 
Code Messages 



MESSAGE 


MEANING 


Command Aborted 


The current command was aborted before it could be 




completed normally. 


Compare Error 


While performing a. Compare command, a Discrepancy 




was found while comparing the disk data to the host 




data. 


Controller Error 


The SDC-RQD11-SCH controller detected an internal 




error, but is able to continue processing its outstanding 




commands. 


Data Error 


An error was detected in the reading or writing of 




data. ECC attempts to read or write data up to 10 




times. If the error persists correction is attempted. If 




correction fails the error is reported. 


Drive Error 


A drive-related error was detected (such as a seek 




failure). 


Media Format Error 


Indicates that the media mounted on the unit was incor- 




rectly formatted. 


Host Buffer Access 


Reports bus time-outs and parity errors during data 


Error 


transfers. (Applies only to the data portion of an 




MSCP command). 


Invalid Command 


The SDC-RQD11-SCH controller found some field in 




the command to be in error. 


Success 


The command was successfully completed. 


Unit Available 


The SDC-RQD11-SCH controller is not on line, but it 




can accept an On Line command from the host. 


Unit Off-line 


The SDC-RQD11-SCH controller is not on line, and it 




cannot be brought on line. 


Write Protected 


A Write or Erase command was attempted to a unit 




that is logically write-protected. 
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5. Operating Systems 



The following discussion is intended to supplement DEC operating system resources 
and aims to aid the user of the SDC-RQD11-SCH in understanding how different 
operating systems integrate the device. This information will help the user of the con- 
troller plan the installation and in choosing the appropriate bus addresses and inter- 
rupt vectors for the disk subsystem. For a complete description the DEC system 
documentation should be consulted. 



5.1 Operating Systems Overview 



In order to install any new device in a computer, the host operating system must be 
informed of the device's existence and where to find that device. In DEC operating 
systems this can be done in one of the following ways: 

a. The device can be manually connected using CONNECT or Configure state- 
ments. 



b. The operating system can be informed about the peripheral device during an in- 
teractive SYSGEN. 



c. The operating system can poll the device I/O address space. 

Any of these methods will accomplish the desired result. The host system will be 
alerted to the device's existence, type, address and interrupt vectors. 

Method (a) creates a command file that is executed on power-up. Method (b), inter- 
active sysgen, creates a configuration file that the operating system accesses on 
power-up. Method (c) is referred to as 'autoconfigure'. RT-11 does not use autocon- 
figure but references standard bus addresses where it expects to find a device. All 
DEC operating systems try to follow the same set of rules but there are differences. 
These are discussed next. 
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MSCP Devices 

The SDC-RQD11-SCH is an MSCP (Mass Storage Control Protocol) type device. 
All MSCP-type devices contain two registers that are visible to the Q-bus I/O page. 
They are the Initialization and Polling (IP) register and the Status and Address (SA) 
register. 

Q-bus Addresses 

The standard Q-bus address of 17772150 (Octal) is used by all of the operating sys- 
tems described in this manual as the address of the first controller on the host sys- 
tem. The IP register, CSR address, Q-bus address and the base address all refer to 
the same register. 



Table 5-1: 
Device Names in 
DEC Operating 
Systems 



OPERATING 


CONTROLLER 


DRIVE 




1st: 


2nd: 


1st: 


2nd: 


RSTS/E 


RUO, 


RU1 


DUO, 


DU1 


RSX-11M 


— 


— 


DUO, 


DU1 


RSX-11M-PLUS 


DUA 


DUB 


DUO, 


DU1 


RT-11 


PortO, 


Portl 


DUO, 


DU1 


VAX/VMS 


PUA, 


PUB 


DUAO, 


DUA1 



Vector Addresses 

Many operating systems choose vector addresses automatically. If an operating sys- 
tem requires manual input of vector addresses they are programmed into the con- 
troller during the initialization process. 

Device Names 

Table 5-1 is a list of device names for five operating systems. Two controller and 
device names are given to indicate the numbering scheme. 



5.2 RT-1 1 Operating System 
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Installation of a Single Controller 

A single controller is installed at the Q-bus address of 17772150 (Octal) where RT- 
11 will find and then install the handler for that device. It is not necessary to run sys- 
gen for a single controller. One of the pre-generated monitors provided with the RT- 
11 distribution kit can be used. To properly implement disk partitioning, the system 
start-up file (STARTx.COM) must be modified. 

Installation of Multiple Controllers 

There are two valid methods that can be used to install multiple controllers. Either 
by modifying the MSCP handler, which is described in the RT-11 Software Support 
Manual or by performing a Sysgen. The following procedure describes the SYSGEN 
technique with user input marked in boldface type. 
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1. Initiate SYSGEN: 



NDSYSGEN < return > 



2. The system will then prompt the user by asking questions. The first concerns the 
use of a start-up command file when booting. 

Do you want the start-up indirect 
file (Y)?Y< return > 

The start-up file performs two main functions. These specify the additional con- 
troller addresses and ensure that disk partitioning is carried out consistently on 
each bootstrap or power-up. 

3. Select the device DU: as the MSCP device when prompted for Disk Options. 

Enter the device name you want support for 
[dd]:DU< return > 

4. Inform the system of the number of controllers to be installed. 

How many ports are to be 
supported (1)? 2 < return > 

RT-11 refers to individual MSCP controllers on the host as ports. Each port has 
its own Q-bus and vector addresses. 

5. All other devices in the host computer configuration have to be specified. After 
completing this step, indicate that there are no more devices by entering a 
period (.). 

Enter the device name you want support for 
[dd]: .< return > 

6. Using the SET CSR keyboard command, specify the address of all the MSCP 
controllers. These must be added to the system start-up file STARTx.COM. 
The Y indicates the monitor to be used - S for single job, F for 
foreground/background, and X for extended memory. The command file must 
be edited to include the following statements : 

SET DUCSR = 17772150 (DEFAULT) 

SET DUCSR2 = 17760334 

SET DU VECTOR = 154 (DEFAULT) 

SET DUVEC2 = 160 

The second device can be at any unused address on the Q-bus I/O page supported 
by the pin settings on the controller. The vector address can be any unused address 
in the vector page. No default statements are required. 
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Disk Partitioning Under RT11 

Drives with capacities greater than 65,535 blocks (33.5 Mbytes) cannot be handled 
by RT-11 unless they are partitioned into smaller segments. Each partition can be 
smaller than 65,535 blocks if desired but there is a maximum of eight logical devices 
per physical drive. Each logical drive will be addressed by RT-11 as an independent 
physical drive. 

The assignment names of each logical drive must be placed in the start-up command 
file to ensure that the drives are partitioned consistently and automatically each time 
the system is booted. The following is an outline of the procedure used to determine 
the number of logical drives to be assigned to each physical drive. 

1. Decide on the drive configuration to be used. The logical unit number (LUN) 
and data storage capacity in logical blocks of each logical drive must be known. 
The controller plug settings must correspond to the bus address selected. 

2. The total number of logical disks any physical disk can be partitioned into is cal- 
culated by dividing the selected block size of each logical disk into the total 
capacity of the the disk unit. Round the result to the nearest whole number. The 
last partition can be less than the maximum size selected. This number equals 
the number of logical disks. 

3. STARTx.COM must now be edited to include the logical names of each parti- 
tion. The format of each statement is : 

SET DUn UNIT = y PART=x PORT = z 

where 'n' is the logical device name, y is the unit number, Y is the partition 
number, and 'z' is the controller number. This must be done for each partition 
on each drive, including drives that have only one partition. 



Sample Disk Partitioning Procedure 

The following is an example of the disk partitioning procedure for a drive of 245,412 
blocks and a drive of 204,800 blocks. It has been decided to partition the drives into 
logical units of 65,535 blocks. 



3.74 ( 4 logical units ) 



(a) 


245,412 




65,535 


(b) 


204,800 




65,535 



3.12 ( 4 logical units ) 



Dividing the unit capacities by 65,535 and rounding the result to the nearest whole 
number gives the number of logical units. If the remainder is very small (under 800 
blocks) then it would be advisable to round the figure down rather than up to the 
next highest number. This may avoid problems with partitions that are too small to 
be practicable. 
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Logical names can then be assigned to the partitions beginning with DUO on control- 
ler unit and modifying the start-up file to include the assignments. 

SET DUO UNIT = PART = PORT = 
SET DU1 UNIT = PART = 1 PORT - 
SET DU2 UNIT = PART = 2 PORT = 
SET DU3 UNIT = PART = 3 PORT = 

SET DU4 UNIT = 1 PART = PORT = 
SET DU5 UNIT = 1 PART = 1 PORT = 
SET DU6 UNIT = 1 PART = 2 PORT = 
SET DU7 UNIT = 1 PART = 2 PORT - 

5.3 RSTS/E Operating Systems (V8.0 and above) 

RSTS/E can support two MSCP type controllers. The first is located at the standard 
Q-bus address (17772150 octal) while the second can be located in floating address 
space. However, the recommended address for the second controller is 17760334. A 
controller must be located at the standard Q-bus address to be a bootstrap device. 

A program called INIT.SYS scans the system on power-up. INIT.SYS references a 
user-specified table located in the currently installed monitor. To alter the autocon- 
figure algorithm, the HARDWARE sub-option of INIT.SYS is used. This modifies 
the configuration table and allows an MSCP controller to be placed at any address 
on the I/O page. If a new monitor is installed then the table must be reset. 

Controllers are assigned vector addresses and programmed by INIT.SYS during in- 
itialization. 

Warning: RSTS/E supports disks of a maximum size of 1,048,576 blocks. Larger 
drives must be broken up into multiple smaller virtual units. At a later date RSTS/E 
may support larger disks, refer to the RSTS/E Software Dispatch for details. 

5.4 RSX-1 1 M Operating Systems (V4.0 and above) 

The RSX-11M SYSGEN program is an interactive program that builds a complete 
and running RSX-11M system for a particular hardware configuration. RSX-11M 
SYSGEN supports autoconfigure. This program detects MSCP type controllers lo- 
cated at standard Q-bus addresses. Additional controllers must be manually at- 
tached to the system according to the procedure outlined below. The procedure is 
fully outlined in the RSX-11M System Generation and Configuration Guide. 

Installing A Single Controller 

A single controller is installed at the standard Q-bus address of 17772150 (Octal). 

Autoconfigure can then be used to connect peripheral devices. 

Installing Multiple MSCP Controllers 

For two controllers manual initialization must be undertaken. The following proce- 
dure will connect the devices to the operating system: 
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1. Invoke SYSGEN. 

> SET/UIC = [200,200] < return > 

> SYSGEN < return > 

2. Indicate that AUTOCONF1GURE has to be used by answering Y (Y) to the 
following: 

Autoconfigure the host system hardware? 
[Y/N]:Y< return > 

3. Indicate that the autoconfigure results are not to be overridden. Answer N (no) 
to the following : 

*Do you want to override Autoconfigure 
results? [Y/N]: N< return > 

Continue to answer the SET-UP questions as required then continue onto the 
TARGET CONFIGURATION section. Target configuration defaults for the 
first group of questions should be accurate because autoconfigure was used. 

4. Indicate the number of devices that are installed. 

* Devices: DU = 2 < return > 
*Devices: . < return > 

Enter the value the correct value of two. The period (.) terminates the device 
input operation. 



The questions over the next four sections - HOST CONFIGURATION, EX- 
ECUTIVE OPTIONS, TERMINAL DRIVER OPTIONS, and SYSTEM OP- 
TIONS - should be answered appropriately. 

5. After answering the above sections it is necessary to define the PERIPHERAL 
OPTIONS for the controllers on the system. The questions will be asked once 
for each controller. The abbreviated form of controller "contr" is used. 



The first prompt is for the interrupt vector address, Q-bus address, the number 
of DU-type disk drives, the number of command rings, and the number of 
response rings. There is no default value for the number of disk drives. 

*DU contr [D:154,17772150„4,4] 
'154,17772150,3,4,4 < return > 

Vector and Q-bus Addresses 

The standard vector address for MSCP controllers is 154 (octal). Any unused vector 
between 300 (octal) and 774 (octal) can be allocated for the second unit. 

The standard Q-bus address of 17772150 (octal) is used for the first controller, while 
the second can be 17760334 (octal) or in floating LSI-11 address space. 
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Drive Configuration 

The following is a list of DEC manufactured drives that are DEC operating system 
compatible. Non-DEC drives must be compatible with those listed below. 

If in doubt consult the manufacturer's specifications to verify compatibility. 

*RX50 
*RD51 
*RD52 

*RC25 
*RA60 
*RA80 
*RA81 

Count each RX50 drive as two drives, these contain two 5.25 inch floppy diskettes. 
The RC25 has both fixed and removable media and should also be counted as two 
drives. 

The configuration of the drives and the logical arrangement (disk partitions) for the 
disk sub-system is programmed by WOMBAT. 

MSCP Ring Buffers 

Command and response ring buffers which MSCP establishes in main memory also 
have to be specified. RSX-11M supports a maximum of eight rings. A value of four 
will minimize system overhead and is the recommended and default value. 

6. The type of disk drives on each controller must now be specified. 



DU contr unit 0. is an RA60/80/81/RC25/RD51/rx50 
[D:RA81] RD51 < return > 

For the RQDX1, indicate that there is a RD51 and two RX50 drives. For the 
SDC-RQD11-SCH, indicate that there is one RD51 for each logical disk drive. 

RSX-11M must have contiguous unit numbers which must be the same as those 
reported by the controller during initialization. 

Warning: Versions of RSX-11M prior to 4.2C support disks of a maximum size of 
1,044,480 blocks. Larger drives must be broken up into multiple smaller virtual units. 

5.5 RSX-1 1 M-Plus Operating Systems (V2.1 & above) 

As with RSX-11M an interactive SYSGEN will build a complete running version of 
RSX-llM-Plus for a particular hardware configuration. RSX-11-Plus supports 
autoconfigure and will detect the first controller located at the standard Q-bus ad- 
dress. Additional controllers must be installed manually. 
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Installing a Single Controller 

A single controller is installed at the standard Q-bus address of 17772150 (octal) 
using autoconfigure to connect the peripherals. The procedure is fully outlined in 
the RSX-llM-Plus System Generation and Configuration Guide. 

Installing Multiple Controllers 

To add the SDC-RQD11-SCH to the system configuration use the Add a Device op- 
tion of SYSGEN or do a complete SYSGEN. The Add a Device procedure is 
described below: 

1. Invoke SYSGEN 

> SET/UIC = [200,200] < return > 

> SYSGEN < return > 

2. Answer N (no) to the following questions to indicate that only a subset of the 
SYSGEN procedure is wanted : 



SU120 Do you want to do a complete SYSGEN? 

[Y/N D:Y]: N < return > 
*SU130 Do you want to continue a previous SYSGEN 
from some point? [Y/N D:Y]: N< return > 

3. Indicate that a specific module of SYSGEN is required by answering Y (yes) to 
the following: 

*SU150 Do you want to do any individual sections 
of SYSGEN? [Y/N D:Y]: Y< return > 

4. Select the Add a Device option of SYSGEN by typing the letter H. 

*SU160 Which sections would you like to do? 
[SR:0.-15.]: H< return > 

SYSGEN now asks questions about the type and number of controllers to be in- 
stalled in the system. There is one question for each controller supported. Type 
(zero) until the prompt for UDA-type devices appears. 

5. Specify the number of MSCP devices when asked by typing: 

"CP3004 How many MSCP disk controllers do you 
have? [D R:0.-63. D:0.] 2 < return > 



6. Give the total number of drives on each controller installed on the system. 

*CP3008 How many MSCP disk drives do you have? 
[D R:0.-n. D:l.] 5 < return > 

The following is a list of DEC manufactured drives that are DEC operating 
compatible. Non-DEC drives must be compatible with those listed on the next 
page. If in doubt consult the manufacturer's specifications to verify compatibility. 
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RX50 
*RD51 
*RD52 
*RC25 
*RA60 
*RA80 
*RA81 

Count each RX50 drive as two drives, these contain two 5.25 inch floppy disks. 
The RC25 has both fixed and removable media and should also be counted as 
two drives. 



The configuration of the drives and the logical arrangement (disk partitions) for 
the disk sub-system is programmed by WOMBAT. 

7. SYSGEN then asks the user to specify controllers for each drive. 

*CP3044 To which DU controller is DUO: 
connected? [S R:l-1]: A < return > 

This question is repeated until the number of MSCP drives has been exhausted. 
RSX-llM-Plus must have contiguous unit numbers and be the same as those 
reported by the controller during initialization or errors will occur. Use A as the 
primary and B as the alternate controller. 

8. Enter the Vector Address for each controller. 

"CP3068 Enter the vector address of DUA 
[O R:-774 D:154] 

The standard vector address for MSCP controllers is 154 (octal). Any unused 
vector between 300 (octal) and 774 (octal) can be allocated for the second unit. 

9. Enter the CSR address for each controller. 

*CP3076 What is its CSR address? 

[O R:l.-8. D:4.] 4 < return > 

The standard CSR address 17772150 (octal) is used for the first controller, 
while the second can be 17772154 (octal) or in floating CSR address space. 



10. Specify the number of command rings for each MSCP controller. 

*CP3076 Enter the number of command rings for 
DUA [D R:l.-8. D:4.] 4 < return > 

RSX-llM-Plus supports a maximum of eight command rings. A value of four 
will minimize system overhead and is the recommended and default value. 
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11. Specify the number of response rings for each MSCP controller. 

CP3076 Enter the number of response rings for 
DUA [D R:l.-8. D:4.] 4 < return > 

RSX-llM-Plus supports a maximum of eight response rings. A value of four 
will minimize system overhead and is the recommended and default value. 

Warning: Versions of RSX-M Plus prior to 3.0C support disks of a maximum size 
of 1,044,480 blocks. Larger drives must be broken up into multiple smaller virtual 
units. 



5.6 MicroVMS Operating Systems 
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The first SDC-RQDll-SCH controller is located at the standard bus address of 
17772150 (Octal) and the second in floating address space. The MicroVMS SYS- 
GEN utility can determine the Q-bus and interrupt vector addresses for any of the 
I/O devices installed on the bus. Micro VAX/Micro VMS must be running in order to 
use this utility. The Q-bus and interrupt vector addresses can be determined manual- 
ly if access to a running system is not possible. 

Using MicroVAX/MicroVMS SYSGEN 

The following is an outline of the MicroVMS SYSGEN procedure to determine Q- 
bus and Interrupt vector addresses. This procedure requires system manager 
privileges. 

1. Log in and run the SYSGEN utility. 

$ RUN SYS$SYSTEM:SYSGEN< return > 

SYSGEN > 

The SYSGEN > prompt indicates that the program is ready. 

2. Obtain a list of the devices currently installed on the Micro VAX Q-bus by 
typing : 

SYSGEN > SHOW/CONFIGURATION < return > 

and get: 



Name: PUA Units: 1 Nexus: CSR: 772150 Vectorl: 154 Vector2: 000 



Name: TXA Units: 1 Nexus: CSR: 760500 Vectorl: 310 Vector2: 000 



Indicates a floating vector or address. 
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Sysgen lists the devices already installed on the Q-bus by logical name. Devices 
with floating bus and vector addresses should be noted if it is intended to re-in- 
stall them with the SDC-RQD11-SCH controller. Floating bus addresses will be 
larger than 760000 (octal). Floating interrupt vectors will be larger than 300 
(octal). 

Execute the configure command. This will determine the Q-bus and Vector ad- 
dresses that autoconfigure will expect for each device type. 

SYSGEN > CONFIGURE < return > 

DEVICE > 

Specify the devices to be installed on the bus by typing their Q- bus names. 
Under MicroVAX/MicroVMS the device name for MSCP-type controllers is 
UDA. 

DEVICE > UDA£< return > 
DEVICE > DHV1K return > 

The device name is separated from the number of devices by a comma. The 
number of devices is specified in decimal. 



Devices with floating addresses or vectors are not affected by devices with fixed 
addresses or vectors. Only devices with floating addresses or vectors need be 
specified. 

5. When all the devices have been specified enter a control-Z. 

DEVICE > CTRL-Z 

The addresses and vectors of the devices entered will be listed in the following 
manner: 



Device: UDA 
Device: UDA 
Device: DHV11 



Name: PUA CSR: 772150^ Vector: 154^ Support: yes 
Name: PUB CSR: 760334* Vector: 300* Support: yes 
Name: TXA CSR: 760500* Vector: 310* Support: yes 



'Denotes floating bus and interrupt vector addresses. Floating CSR addresses 
must be programmed into the SDC-RQD11-SCH by selecting the correct pin 
configuration on the PCB. 

6. If an address other than that selected for the SDC-RQD11-SCH by CON- 
FIGURE command is desired, CONNECT statements must be entered into the 
SYSCONIF.COM file. SYSCONIF.COM can only be accessed through the sys- 
tem manager's account SYS$MANAGER. The correct syntax is given in the 
DEC MicroVMS SYSGEN documentation. 



The STARTUP.COM or UVSTART.COM command files in the main system 
account, SYS$SYSTEM must not be altered. 
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5.7 Autoconfigure 



Autoconfigure is a utility program that finds and identifies I/O devices in the I/O 
page of system memory. Most devices have a fixed bus address reserved for them. 
When the computer is bootstrapped autoconfigure polls those addresses - specifical- 
ly the console status register (CSR) which is usually the first register of the block. 

A block of addresses is reserved when a device is detected. The size of the block is 
determined by the number of registers the device uses. Autoconfigure then looks to 
the next CSR address space for that same type of device. If there are no other 
devices of that type autoconfigure looks to the next valid CSR address. Autocon- 
figure expects an eight byte block to be reserved for each device not installed in the 
system. An empty block tells autoconfigure to look to the next valid address space. 

Devices with no fixed address are assigned addresses from floating CSR address 
space. This may be necessary if there are several of the same device in the system. 
Floating address space is in the vicinity of 76000 to 763776 of the bus I/O page. 
Devices can also have floating interrupt vector addresses. Floating CSR and inter- 
rupt vectors must be assigned in specific sequences depending on the rank of the 
device (see Table 5-2). The presence or absence of floating bus and interrupt vector 
address devices will affect the assignment of addresses to other floating vector 
devices. 



Table 5-2: 
SYSGEN Device 
Ranking 







Number of 


Octal 






Number of 


Octal 


Rank 


Device 


Registers 


Modulus 


Rank 


Device 


Registers 


Modulus 


1 


DJll 


4 


10 


17 


Reserved 

RX11 2 

RX211 2 

RXV11 2 

RXV21 2 


4 


10 


2 


DH11 


8 


20 


18 


4 


10 


3 


DQ11 


4 


10 


18 


4 


10 


4 


DU11, DUV11 


4 


10 


18 


4 


10 


5 


DUP11 


4 


10 


18 


4 


10 


6 


LK11A 


4 


10 


19 


DR11-W 


4 


10 


7 


DMC11 


4 


10 


20 


DR11-B 3 


4 


10 


7 


DMR11 


4 


10 


21 


DMP11 


4 


10 


8 


DZ11 1 


4 


10 


22 


DPV11 


4 


10 


8 


DZV11 


4 


10 


23 


ISB11 


4 


10 


8 


DZS11 


4 


10 


24 


DMV11 


8 


20 


8 


DZ32 


4 


10 


25 


DEUNA 2 
UDA50 2 


4 


10 


9 


KMC11 


4 


10 


26 


2 


4 


10 


LPP11 


4 


10 


27 


DMF32 


16 


40 


11 


VMV21 


4 


10 


28 


KMS11 


6 


20 


12 


VMV31 


8 


20 


29 


VS100 


8 


20 


13 


DWR70 

RLir 


4 


10 


30 


TU81 


2 


4 


14 


4 


10 


31 


KMV11 


8 


20 


14 


RLV11 2 


4 


10 


32 


DHV11 


8 


20 


15 


LPA11-K 2 


8 


20 


33 


DMZ32 


16 


40 


16 


KW11-C 


4 


10 


34 


CP132 


16 


40 



^Zll-E and DZ11-F treated as two DZlls. 

nThe first device of this type has a fixed address while extra devices have floating 

addresses. 
TThe first two devices of this type have fixed addresses while extra devices have 

floating addresses. 
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An eight byte gap must also be reserved in floating address space for each device 
type not currently installed in the system. This gap must start on the proper bound- 
ary. See Table 5.6 for an example of gap placement. 

A device's CSR address is determined on word boundaries according to the number 
of bus accessible registers the device has. The relationship of word boundaries and 
device registers is set out in Table 5-3. Autoconfigure only inspects for a device type 
at one of the possible device boundaries. For instance, autoconfigure will not look 
for a DMZ32 which has 16 registers at an address that ends in 20. 



Table 5-3: 


DEVICE REGISTERS 


POSSIBLE BOUNDARIES 


Device Registers 






and Word 


1 


Any word 


Boundaries 


2 


XXXXXO, XXXXX4 




3,4 


XXXXXO 




5, 6, 7, 8 


XXXX00, XXXX20, XXXX40, XXXX60 




9 through 16 


XXXX00, XXXX40 



Vector Addresses and Autoconfiguration 

Devices are assigned vector addresses in order of rank commencing at 300 (octal) 
up to 777 (octal). Extra devices of the same type are assigned consecutive vector ad- 
dresses according to the number of vectors required and starting boundaries for 
each device type. Table 5-4 shows the order of assignment. 

The boundaries in the modulus column indicate where vector addresses are as- 
signed. If the modulus is 10 the first vector address for that device must end with a 
zero (XXO). If the modulus is 4 the first vector must end with with either a zero or 
four (XXO, XX4). 

Vector addresses can only end on an address of four or zero i.e. modulo 4 boun- 
daries (XXO, XX4). If a device has two vectors the first must start on a modulo 10 
boundary. Using 350 as a starting point the vectors will be 350 and 354. 
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Table 5-4: 
Floating Vector 
Address Priority 
Ranking 





Number of Octal 






Number of Octal 


Rank 


Device Vectors Modulus 


Rank 


Device 


Vectors Modulus 


1 


DCll 


2 


10 


28 


KMCll 


2 


10 


l 


TU58 
KL11 1 


2 


10 


29 


LPP11 


2 


10 


2 


2 


10 


30 


VMV21 


2 


10 


2 


DL11-A 1 
DL11-B 1 


2 


10 


31 


VMV31 


2 


10 


2 


2 


10 


32 


VTV01 


2 


10 


2 


DLV11-J 1 


8 


40 


33 


DWR70 


2 


10 


2 


DLVll.DLVll-F 1 


2 


10 


34 


RL11/RLV11 2 
TS11 2 ,TU80 2 


1 


4 


3 


DP11 


2 


10 


35 


1 


4 


4 


DM11-A 


2 


10 


36 


LPA11-K 


2 


10 


5 


DN11 


1 


4 


37 


IP11/IP300 2 


1 


4 


6 


DM11-BB/BA 


1 


4 


38 


KW11-C 
RX11 2 


2 


10 


7 


DH11 modem control 


1 


4 


39 


1 


4 


8 


DR11-A.DRV11-B 


2 


10 


39 


RX211 2 


1 


4 


9 


DR11-CDRV11 


2 


10 


39 


RXV11 2 


1 


4 


10 


PA611(reader + punch)4 


20 


39 


RXV21 2 


1 


4 


11 


LPD11 


2 


10 


40 


DR11-W 


1 


4 


12 


DT07 


2 


10 


41 


DR11-B 2 


1 


4 


13 


DX11 


2 


10 


42 


DMP11 


2 


10 


14 


DL11-CTODLV11-F2 


10 


43 


DPV11 

ML11 3 


2 


10 


15 


DJ11 


2 


10 


44 


1 


4 


16 


DH11 


2 


10 


45 


ISB11 


2 


10 


17 


VT40 


4 


20 


46 


DMV11 


2 


10 


17 


VSV11 


4 


10 


47 


DEUNA 2 
UDA50 2 


1 


4 


18 


LPS11 


6 


40 


48 


1 


4 


19 


DQ11 


2 


10 


49 


DMF32 


8 


40 


20 


KW11-W, KWV11 


2 


10 


50 


KMS11 


3 


20 


21 


DU11, DUV11 


2 


10 


51 


PCL11-B 


2 


10 


22 


DUP11 


2 


10 


52 


VS100 


1 


4 


23 


DV11 + modem control3 


20 


53 


Reserved 


1 


4 


24 


LK11-A 


2 


10 


54 


KMV11 


2 


10 


25 


DWUN 


2 


10 


55 


Reserved 


2 


10 


26 


DMC11 


2 


10 


56 


IEX 


2 


10 


26 


DMR11 


2 


10 


57 


DHV11 


2 


10 


27 


DZ11/DZS11/DZV11 


2 


10 


58 


DMZ32 


6 


20 


27 


DZ32 


2 


10 


59 


CP132 


6 


20 



KL11 or DL11 have fixed vectors when used as a console. 
Tlie first device has a fixed vector all subsequent device of the same type have a 
floating vector. 

ML11 is a Mass Bus device which connects to the Q-bus or Unibus via a bus 
adapter. 

System Configuration Example 

An example of a system configuration is shown in Table 5-5. The configuration in- 
cludes both fixed and floating addresses and vectors. 



Table 5-5: 
CSR and Vector 
Address Example 



CONTROLLER 


VECTOR 


CSR 


1UDA50 


154 


772150 


1DZ11 


300 


760100 


1UDA50 


310 


760334 


2DHV11 


320 


760520 




330 


760520 
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Table 5-6 shows the computed CSR addresses and gaps for floating devices. 



Table 5-6: 
Floating CSR 
Address 
Assignment 



INSTALLED 


DEVICE 




ADDRESS 




DJ11 


Gap 


760010 




DH11 


Gap 


760020 




DQ11 


Gap 


760030 




DU11 


Gap 


760040 




DUP11 


Gap 


760050 




LK11A 


Gap 


760060 




DMC11 


Gap 


760070 


> 


DZ11 




760100 




KMC11 


Gap 


760120 




LPP11 


Gap 


760130 




VMV21 


Gap 


760140 




VMV31 


Gap 


760150 




DWR70 


Gap 


760170 




RL11 


Gap 


760200 




LPA11-K 


Gap 


760220 




KW11-C 


Gap 


760230 




Reserved 


Gap 


760240 




RX11 


Gap 


760250 




DR11-W 


Gap 


760260 




DR11-B 


Gap 


760270 




DMP11 


Gap 


760300 




DPV11 


Gap 


760310 




ISB11 


Gap 


760320 




DMV11 


Gap 


760330 




DEUNA 


Gap 


760340 


> 


UDA50 (SDC-RQD11-SCH) 


772334 1 


> 


UDA50 (SDC-RQD11-SCH) 


760354 






Gap 


760360 




DMF32 


Gap 


760400 






Gap 


760440 




KMS11 


Gap 


760420 




VS100 


Gap 


761440 




TU81 


Gap 


761450 




KMV11 


Gap 


761460 


> 


DHV11 




761500 


> 


DHV11 




761520 






Gap 


761530 




DMZ32 


Gap 


761540 




CP132 


Gap 


761600 



indicates a fixed address device 
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6. Cache Operation 



6.1 Disk Cache 



The SDC-RQD11-SCH implements a disk cache which is designed to facilitate 
larger and faster data transfers between disk and the host by reducing the time 
wasted on positioner operations. Even with fast drives 98% of disk time for con- 
tinuous random access to single sectors of data is taken by positioner operations. 
The SDC-RQD11-SCH offers at least an 80% improvement in access times by 
reducing the number of disk accesses required. The SDC-RQD11-SCH cache is im- 
plemented as one megabyte of dynamic RAM. 



6.2 Read Look-ahead 



The SDC-RQD11-SCH allows the user to program the controller to perform read 
look-ahead in anticipation of impending data requests. The optimum look-ahead 
value can only be determined within system and application parameters but can 
range from to 255 blocks. A value of zero will disable the feature. The default 
value is four. 

The anticipated hit ratio for the SDC-RQD11-SCH cache is 90% although this can 
be reduced depending upon the nature of the data accessed. Because most user 
programs write and read data sequentially there is a high probability that in one 
fetch operation the controller will be able to satisfy several sequential data reads 
without the need for further disk accesses. 

The cache has been designed to maximize the probability of finding the target data 
over a range of sequential and non-sequential reference patterns while minimizing 
cache misses and controller overhead. 



6.3 Cache Allocation 



Cache memory is used to hold the disk cache blocks, a cache map and fixed buffers 
for special usage. Data from the disk or main memory is stored in blocks at addres- 
ses determined by the cache assignment algorithm. Their contents and location are 
recorded in the cache map. 
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The cache map consists of a 4-byte entry for each cache block. The cache map is in- 
dexed by the cache block numberand contains the address (drive number, logical 
block) of the current occupant together with flags (locked, valid, primary copy not 
written, shadow copy not written). 

Fixed buffers are assigned for RCT buffers (1 per drive) and a single block buffer 
for disk management I/O. The location and size of all cache variables are held in 
RAM. 



6.4 Cache Usag e 



All disk I/O is done via the cache. A set of cache blocks must be assigned for all 
transfers and continuous disk operations must be done via contiguous cache blocks. 
Disk and Q-bus transfers are performed simultaneously. 



6.5 Cache Assignment Algorithm 



The SDC-RQD11-SCH cache implements a contention based hashing algorithm to 
determine block replacement. A given disk block has a fixed cache address calcu- 
lated as follows: 

a. Get the remainder of the logical block number modulo the number of cache 
blocks. 

b. Bias this by a fixed offset which is a function of the drive number. (This is so 
that the same logical block on 2 disks have a different cache block number). 

A disk block also has an alternative cache address calculated by biasing it by ap- 
proximately half the number of cache blocks. The alternate cache block is only used 
for compare operations. 



6.6 Cache Operation 



The following describes the cache operation algorithm: 
Read: 

Examine cache for data required. 

If all data in cache transfer data from cache to Q-bus 
or else 

Assign cache (lock it and wait if locked already) 
Perform read 

Unlock cache and flag as valid 
Write: 

Assign cache (lock it and wait if locked already) 
Transfer from Q-bus to cache and flag as valid 
Perform write 
Unlock cache 
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6.7 Cache Disable 



The SDC-RQD11-SCH cache can be disabled for performance evaluation, engineer- 
ing, and diagnostic application requirements by selecting that option in WOMBAT. 
The cache cannot be selectively disabled for a particular drive. 



6.8 Early Write Notification 



The SDC-RQD11-SCH implements early write notification where data to be written 
to disk is retained in the cache and the host is issued a write complete notification. 
The controller will then write the data to the disk at the most convenient time. 

Early Write Notification should be disabled when saving the boot block on the sys- 
tem volume. If it is not disabled, a subsequent reset instruction will clear the cache 
memory and the boot data will not be written to disk. 

Note: In the event of system failure, any data residing in the cache will be lost. The 
early write notification can be disabled by invoking WOMBAT and selecting the ap- 
propriate option. 
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7. SMD Interface 



The Storage Module Drive (SMD) interface is an industry standard for high 
capacity disk drives. The basic interface consists of a control cable (J3), data 
(read/write) cable (Jl and 32), and a ground cable. The SDC-RQD11-SCH uses 
flat-ribbon cables for connection to Jl through J3. 

The control cable connects each drive to the host in either radial or daisy-chained 
configuration. The maximum cable length is 30 metres. The control cable is 
terminated on the last drive. The data (read/write) cable connects to each drive in a 
radial fashion only and has a maximum length of 15 metres. The data (read/write) 
cable is terminated at the last drive. Ground cabling should establish the host, drives 
and cabinets at the same safety ground reference. 

The SMD interface has been modified by various manufacturers. The 
SDC-RQD11-SCH supports the following types of SMD interface with no software 
or hardware changes. All the modified versions of the SMD interface implement the 
minimum set of requirements of interchangeability and compatibility for SMD 
devices but with degrees of flexibilty. 

Standard 1024 Cylinder address capability 
1 Byte status available 

9 Control functions 
Modified 4096 Cylinder address capability 

4 Byte status available 
12 Control functions 
Enhanced 2048 Cylinder address capability 
1 Byte status available 

10 Control functions 
Extended 1M Cylinder address capability 

16 Byte status available 
19 Control functions 

Pin assignments for the various SMD interface types are listed in Appendix A. The 
SMD documentation should be consulted for a detailed explanation of the specific 
function details of each SMD interface type. 

The data (Read/Write) cable is common to all of the SMD interface types. Table 
7-1 shows the Pin assignments. 
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Table 7-1: 
SMD Standard 
Control Cable 
Signals 



SIGNAL NAME 



DEVICE SELECT ENABLE 

DEVICE SELECT 

DEVICE SELECT 1 

DEVICE SELECT 2 

DEVICE SELECT 3 

TAG1 

TAG 2 

TAG 3 

TAG BUS (BO) 

TAG BUS 1 (Bl) 

TAG BUS 2 (B2) 

TAG BUS 3 (B3) 

TAG BUS 4 (B4) 

TAG BUS 5 (B5) 

TAG BUS 6 (B6) 

TAG BUS 7 (B7) 

TAG BUS 8 (B8) 

TAG BUS 9 (B9) 

INTERFACE ENABLE 

STATUS (UNIT READY) 

STATUS 1 (ON CYLINDER) 

STATUS 2 (SEEK ERROR) 

STATUS 3 (FAULT) 

STATUS 4 (WRITE PROTECTED) 

STATUS 5 (ADDRESS MARK) 

STATUS 6 (INDEX) 

STATUS 7 (SECTOR) 

BUSY 

PICK 
SEQUENCE 

SPARE 



SOURCE 



SIGNAL PIN 





+ 


- 


HOST 


44 


43 


HOST 


46 


45 


HOST 


48 


47 


HOST 


52 


51 


HOST 


54 


53 


HOST 


2 


1 


HOST 


4 


3 


HOST 


6 


5 


HOST 


8 


7 


HOST 


10 


9 


HOST 


12 


11 


HOST 


14 


13 


HOST 


16 


15 


HOST 


18 


17 


HOST 


20 


19 


HOST 


22 


21 


HOST 


24 


23 


HOST 


26 


25 


HOST 


8 


27 


DEVICE 


38 


37 


DEVICE 


34 


33 


DEVICE 


32 


31 


DEVICE 


30 


29 


DEVICE 


56 


55 


DEVICE 


40 


39 


DEVICE 


36 


35 


DEVICE 


50 


49 


- 


42 


41 



57 
58 



60 



59 
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Table 7-2: 










SMD Extended 


SIGNAL NAME 


SOURCE 


SIGNAL PIN 


Control Cable 






+ 


- 


Signals 


DEVICE SELECT ENABLE 


HOST 


44 


43 




DEVICE SELECT 


HOST 


46 


45 




DEVICE SELECT 1 


HOST 


48 


47 




DEVICE SELECT 2 


HOST 


52 


51 




DEVICE SELECT 3 


HOST 


54 


53 




TAG1 


HOST 


2 


1 




TAG 2 


HOST 


4 


3 




TAG 3 


HOST 


6 


5 




TAG 4 


HOST 


60 


59 




TAG BUS (BO) 


HOST 


8 


7 




TAG BUS 1 (Bl) 


HOST 


10 


9 




TAG BUS 2 (B2) 


HOST 


12 


11 




TAG BUS 3 (B3) 


HOST 


14 


13 




TAG BUS 4 (B4) 


HOST 


16 


15 




TAG BUS 5 (B5) 


HOST 


18 


17 




TAG BUS 6 (B6) 


HOST 


20 


19 




TAG BUS 7 (B7) 


HOST 


22 


21 




TAG BUS 8 (B8) 


HOST 


24 


23 




TAG BUS 9 (B9) 


HOST 


26 


25 




INTERFACE ENABLE 


HOST 


28 


27 




STATUS (UNIT READY) 


DEVICE 


38 


37 




STATUS 1 (ON CYLINDER) 


DEVICE 


34 


33 




STATUS 3 (FAULT) 


DEVICE 


30 


29 




STATUS 4 (WRITE PROTECTED) 


DEVICE 


56 


55 




STATUS 5 (ADDRESS MARK) 


DEVICE 


40 


39 




STATUS 6 (INDEX) 


DEVICE 


36 


35 




STATUS 7 (SECTOR) 


DEVICE 


50 


49 




BUSY 


- 


42 


41 




ROTATIONAL POSITIONING (INDEX) - 




57 




ROTATIONAL POSITIONING (SECTOR) - 




58 
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Table 7-3: 
SMD Modified 
Control Cable 
Signals 



SIGNAL NAME 


SOURCE 


SIGNAL PIN 


DEVICE SELECT ENABLE 


HOST 


44 


43 


DEVICE SELECT 0/TAG BUS 10 (BIO) HOST 


46 


45 


DEVICE SELECT 1 


HOST 


48 


47 


DEVICE SELECT 2 


HOST 


52 


51 


DEVICE SELECT 3 / TAG 5 


HOST 


54 


53 


TAG1 


HOST 


2 


1 


TAG 2 


HOST 


4 


3 


TAG 3 


HOST 


6 


5 


TAG 4 


HOST 


60 


59 


TAG BUS (BO) 


HOST 


8 


7 


TAG BUS 1 (Bl) 


HOST 


10 


9 


TAG BUS 2 (B2) 


HOST 


12 


11 


TAG BUS 3 (B3) 


HOST 


14 


13 


TAG BUS 4 (B4) 


HOST 


16 


15 


TAG BUS 5 (B5) 


HOST 


18 


17 


TAG BUS 6 (B6) 


HOST 


20 


19 


TAG BUS 7 (B7) 


HOST 


22 


21 


TAG BUS 8 (B8) 


HOST 


24 


23 


TAG BUS 9 (B9) 


HOST 


26 


25 


INTERFACE ENABLE 


HOST 


28 


27 


STATUS (UNIT READY) 


DEVICE 


38 


37 


STATUS 1 (ON CYLINDER) 


DEVICE 


34 


33 


STATUS 2 (SEEK ERROR) 


DEVICE 


32 


31 


STATUS 3 (FAULT) 


DEVICE 


30 


29 


STATUS 4 (WRITE PROTECTED) 


DEVICE 


56 


55 


STATUS 5 (ADDRESS MARK) 


DEVICE 


40 


39 


STATUS 6 (INDEX) 


DEVICE 


36 


35 


STATUS 7 (SECTOR) 


DEVICE 


50 


49 


BUSY 


- 


42 


41 


PICK 


- 


57 




SEQUENCE 


■ 


58 
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Table 7-4: 
SMD Enhanced 
Control Cable 
Signals 



SIGNAL NAME 


SOURCE 


SIGNAL PIN 


DEVICE SELECT ENABLE 


HOST 


+ 
44 


43 


DEVICE SELECT 


HOST 


46 


45 


DEVICE SELECT 1 


HOST 


48 


47 


DEVICE SELECT 2 


HOST 


52 


51 


DEVICE SELECT 3 


HOST 


54 


53 


TAG1 


HOST 


2 


1 


TAG 2 


HOST 


4 


3 


TAG 3 


HOST 


6 


5 


TAG BUS (BO) 


HOST 


8 


7 


TAG BUS 1 (Bl) 


HOST 


10 


9 


TAG BUS 2 (B2) 


HOST 


12 


11 


TAG BUS 3 (B3) 


HOST 


14 


13 


TAG BUS 4 (B4) 


HOST 


16 


15 


TAG BUS 5 (B5) 


HOST 


18 


17 


TAG BUS 6 (B6) 


HOST 


20 


19 


TAG BUS 8 (B8) 


HOST 


24 


23 


TAG BUS 9 (B9) 


HOST 


26 


25 


TAG BUS 10 (BIO) 


HOST 


60 


59 


INTERFACE ENABLE 


HOST 


28 


27 


STATUS (UNIT READY) 


DEVICE 


38 


37 


STATUS 1 (ON CYLINDER) 


DEVICE 


34 


33 


STATUS 2 (SEEK ERROR) 


DEVICE 


32 


31 


STATUS 3 (FAULT) 


DEVICE 


30 


29 


STATUS 4 (WRITE PROTECTED) 


DEVICE 


56 


55 


STATUS 5 (ADDRESS MARK) 


DEVICE 


40 


39 


STATUS 6 (INDEX) 


DEVICE 


36 


35 


STATUS 7 (SECTOR) 


DEVICE 


50 


49 


BUSY 


- 


42 


41 


PICK 




57 




SEQUENCE 


- 


58 
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Table 7-5: 
SMD Read/Write 
Cable Signals 



SIGNAL NAME 


SOURCE 


SIGNAL PIN 






+ 


- 


GND 


WRITE DATA 


HOST 


14 


15 


13 


WRITE CLOCK 


HOST 


12 


11 


10 


SERVO CLOCK 


DEVICE 


2 


3 


1 


READ CLOCK 


DEVICE 


8 


9 


7 


SELECTED 


DEVICE 


17 


18 


16 


SEEK END 


DEVICE 


20 


19 


21 


INDEX MARK 


DEVICE 


22 


23 


24 


SECTOR MARK 


DEVICE 


26 


25 




READ DATA 


DEVICE 


6 


5 


4 
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8. Q-bus Interface 



All data, address and control information transfers between the processor and disk 
controller are carried out over the Q-bus. The SDC-RQD11-SCH supports all 
current Q-bus functions including block mode DMA, 22 bit addressing, 4-level 
position independent interrupt structure, all LSI-11 CPUs and Micro VAX II. 

The Q-bus consists of 42 bi-directional and 2 unidirectional signal lines wired into 
the backplane assembly. These are grouped into the following categories: 



• Sixteen multiplexed data/address lines - BDAL< 15:00 > 

• Two multiplexed address/parity lines - BDAL< 17:16 > 

• Four extended address lines - BDAL<21:18> 

• Six data transfer control lines - BBS7L, BDINL, BDOUTL, BRPLYL, 
BSYNCL, BWTBTL 

• Six system control lines - BHALTL, BREFL, BEVNTL, BINITL, 
BDCOKL, BPOKL 

• Ten interrupt control and direct memory access control lines - BIAKOL, 
BIAKIL, BIRQ4L, BIRQ5L, BIRQ6L, BIRQ7L, BDMGOL, BDMRL, 
BSACKL, BDMGIL 



Communication is asynchronous, allowing devices with differing data rates to share 
the bus. A strict master/slave protocol avoids the need for synchronizing clock 
pulses by implementing handshaking and other control signals between I/O devices. 
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8. 1 Interrupts 



Interrupt priority for the SDC-RQD11-SCH is switch selectable on the PCB. The 
recommended priority setting is five. In order to service LSI-11 and LSI-11/2 CPUs 
the SDC-RQD11-SCH automatically outputs level four interrupts despite switch 
priority selections. 

Interrupts suspend program execution while the processor starts the device service 
routine at a vector address input from the requesting device. 

Interrupts are serviced according to device priority. Device priority can be 
determined in two ways. These are termed "Position Defined' and 'Distributed' 
arbitration. Positioned Defined arbitration gives priority to those devices which are 
electrically closest to the processor. Distributed arbitration implements priority 
according to the priority levels set on the device hardware. When devices with equal 
priority generate an interrupt, the processor gives preference to the device which is 
electrically closest. A previous bus transaction must have been completed before 
another can be commenced. 

The interrupt protocol has three phases: 

1. Interrupt Request Phase. The interrupt enable bit in the status register is set 
and interrupt request lines are asserted according to priority settings. 

2. Interrupt Acknowledge and Priority Arbitration Phase. The processor detects 
the request and checks if any other device with higher priority is requesting an 
interrupt. If there are no devices with higher priority seeking an interrupt the 
processor acknowledges the interrupt. 

3. Interrupt Vector Transfer Phase. The device outputs vector address bits to the 
processor which then enters the device service routine. 



8.2 Direct Memory Access 



The SDC-RQD11-SCH supports both normal and block mode Direct Memory 
Access (DMA). During a DMA transfer the processor passes mastership of the bus 
to the controller. 

During block mode DMA transfer the SDC-RQD11-SCH has a four microsecond 
delay after every 16 words to service any pending interrupt or DMA requests from 
other devices. The SDC-RQD11-SCH also detects DMA requests from other 
devices and will implement a 'DMA Throttle' after eight words. This prevents data 
loss from other DMA devices which may also share the Q-bus. 

The SDC-RQD11-SCH interleaves address references with bursts of data during 
DMA. Because the starting memory address is asserted only once every sixteen data 
words so data throughput is almost doubled. 
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DMA protocol consists of three phases: 

1. Bus Mastership Acquisition Phase. The SDC-RQD11-SCH requests control of 
the bus. The processor arbitrates the request then initiates the transfer of bus 
mastership. 

2. Data Transfer Phase. The processor provides the controller with the following 
information utilizing MSCP - block number on the disk, the number of bytes to 
transfer, and address in main memory, and if the operation is a read or write. 

3. Bus Mastership Relinquish Phase. Bus mastership is relinquished after complet- 
ing or aborting the data transfer cycle. 

For a detailed description of the Q-bus the appropriate DEC manual should be 
consulted. 
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A. Base (CSR) Address (Jumper A1-A6) 



A6 


A5 


A4 


A3 


A2 


Al 


CSR ADDRESS 


OUT 


OUT 


OUT 


OUT 


OUT 


IN 


17760720 


OUT 


OUT 


OUT 


OUT 


IN 


OUT 


17760714 


OUT 


OUT 


OUT 


OUT 


IN 


IN 


17760710 


OUT 


OUT 


OUT 


IN 


OUT 


OUT 


17760704 


OUT 


OUT 


OUT 


IN 


OUT 


IN 


17760700 


OUT 


OUT 


OUT 


IN 


IN 


OUT 


17760674 


OUT 


OUT 


OUT 


IN 


IN 


IN 


17760670 


OUT 


OUT 


IN 


OUT 


OUT 


OUT 


17760664 


OUT 


OUT 


IN 


OUT 


OUT 


IN 


17760660 


OUT 


OUT 


IN 


OUT 


IN 


OUT 


17760654 


OUT 


OUT 


IN 


OUT 


IN 


IN 


17760650 


OUT 


OUT 


IN 


IN 


OUT 


OUT 


17760644 


OUT 


OUT 


IN 


IN 


OUT 


IN 


17760640 


OUT 


OUT 


IN 


IN 


IN 


OUT 


17760634 


OUT 


OUT 


IN 


IN 


IN 


IN 


17760630 


OUT 


OUT 


IN 


OUT 


OUT 


OUT 


17760624 


OUT 


OUT 


IN 


OUT 


OUT 


IN 


17760620 


OUT 


OUT 


IN 


OUT 


IN 


OUT 


17760614 


OUT 


OUT 


IN 


OUT 


IN 


IN 


17760610 


OUT 


OUT 


IN 


IN 


OUT 


OUT 


17760604 


OUT 


OUT 


IN 


IN 


OUT 


IN 


17760600 


OUT 


OUT 


IN 


IN 


IN 


OUT 


17760574 


OUT 


OUT 


IN 


IN 


IN 


IN 


17760570 


OUT 


IN 


IN 


OUT 


OUT 


OUT 


17760564 


OUT 


IN 


IN 


OUT 


OUT 


IN 


17760560 


OUT 


IN 


IN 


OUT 


IN 


OUT 


17760554 


OUT 


IN 


IN 


OUT 


IN 


IN 


17760550 


OUT 


IN 


IN 


IN 


OUT 


OUT 


17760544 


OUT 


IN 


IN 


IN 


OUT 


IN 


17760540 


OUT 


IN 


IN 


IN 


IN 


OUT 


17760534 


OUT 


IN 


IN 


IN 


IN 


IN 


17760530 


IN 


OUT 


OUT 


OUT 


OUT 


OUT 


17760524 


IN 


OUT 


OUT 


OUT 


OUT 


IN 


17760520 


IN 


OUT 


OUT 


OUT 


IN 


OUT 


17760514 


IN 


OUT 


OUT 


OUT 


IN 


IN 


17760510 


IN 


OUT 


OUT 


IN 


OUT 


OUT 


17760504 


IN 


OUT 


OUT 


IN 


OUT 


IN 


17760500 


IN 


OUT 


OUT 


IN 


IN 


OUT 


17760474 


IN 


OUT 


OUT 


IN 


IN 


IN 


17760470 
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A6 


A5 


A4 


A3 


A2 


Al 


CSR ADDRESS 


IN 


OUT 


IN 


OUT 


OUT 


OUT 


17760464 


IN 


OUT 


IN 


OUT 


OUT 


IN 


17760460 


IN 


OUT 


IN 


OUT 


IN 


OUT 


17760454 


IN 


OUT 


IN 


OUT 


IN 


IN 


17760450 


IN 


OUT 


IN 


IN 


OUT 


OUT 


17760444 


IN 


OUT 


IN 


IN 


OUT 


IN 


17760440 


IN 


OUT 


IN 


IN 


IN 


OUT 


17760434 


IN 


OUT 


IN 


IN 


IN 


IN 


17760430 


IN 


IN 


OUT 


OUT 


OUT 


OUT 


17760424 


IN 


IN 


OUT 


OUT 


OUT 


IN 


17760420 


IN 


IN 


OUT 


OUT 


IN 


OUT 


17760414 


IN 


IN 


OUT 


OUT 


IN 


IN 


17760410 


IN 


IN 


OUT 


IN 


OUT 


OUT 


17760404 


IN 


IN 


OUT 


IN 


OUT 


IN 


17760400 


IN 


IN 


OUT 


IN 


IN 


OUT 


17760374 


IN 


IN 


OUT 


IN 


IN 


IN 


17760370 


IN 


IN 


IN 


OUT 


OUT 


OUT 


17760364 


IN 


IN 


IN 


OUT 


OUT 


IN 


17760360 


IN 


IN 


IN 


OUT 


IN 


OUT 


17760354 


IN 


IN 


IN 


OUT 


IN 


IN 


17760350 


IN 


IN 


IN 


IN 


OUT 


OUT 


17760344 


IN 


IN 


IN 


IN 


OUT 


IN 


17760340 


IN 


IN 


IN 


IN 


IN 


OUT 


17760334 


IN 


IN 


IN 


IN 


IN 


IN 


17772150 


IN = 1 














OUT = 
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Index 



A 

Access • -13 

Altitude -7 

Autoconfigure -62 

CSR address, floating .62 

Vector address 63 

Automatic bootstrap select 
See Bootstrap operation 

B 

Bad block mapping 6 

Bit length of defect 32 

Block transfer delay 4 

Block transfer time 4 

Blocks replaced 28 

Boot address -5 

Bootstrap operation 

Automatic bootstrap select 11 

Bootstrap enabled -15 

Bootstrap procedure 15 

CSR bootstrap address 16 

Bytes past index 32 

Bytes per sector 32 

c 

Cache : -1 

Cache assignment algorithm 5, 68 

Cache enable 26 

Cache high rate 5 

Cache memory -1 

Cache operation £8 

Cache read execution time 5 

CDC 9715 Winchester 37 

Command and response rings .42 

Command queue 26 

Command transmission 45 

Commands 28 

CONFIGURE. 10 

Controller statistics report 28 

CPU type 12 

CSR address configuration 10, 18 

CSR address selection 5 

CSR bootstrap address 

See Bootstrap operation 
Cylinder 24,32 
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D 

Daisy chain .14 

Data interface .7 

Data transfers 1 

DEC 1 

Descriptors 42 

Device names 52 

Dimensions -7 

Disk cache j67 

Disk structure 

See WOMBAT utilities 

Disk transfer overhead 5 

Display statistics 28 

DMA 

Block mode DMA 2, 78 

DMA throttle 2,78 

Drive cabling 14 

Drive interface 1, 7 

See also Interface type 
Drive shadowing 2, 6, 32 

See also WOMBAT utilities 

Drive statistics report 28 

Drive structure specification 

See WOMBAT utilities 

Drives with removable media 35 

Dual drive configuration cable kit .9 

Dynamic bad block replacement 3 

E 

Early write notification .69 

ECC 2,6,36,49 

See also WOMBAT utilities 
Error Correction and Checking 

See ECC 

Error recovery 32 

Error recovery procedures 

See ECC 

See also WOMBAT utilities 
External panel , j6 

controls 6 

LEDs , 6 

RS-232port .7 

F 

Factory configurations .9 

Fairness count 25 

Fatal error .49 

Front panel connections 13 

Front panel connector pinouts 13 

Front panel type 27 

Full sectors/track , 24 
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H 

HDR 29 

Head 24,32 

Head spiraling 6 

Host write confirm 26 

Humidity 7 

I 

Initialization procedures 39, 46 

Installation 9 

RSX-11M multiple controllers .55 

RSX-11M Plus multiple controllers 58 

RSX-11M Plus single controller .58 

RSX-11M single controller 55 

RT11 multiple controller 52 

RT11 single controller 52 

Interface type 25 

Interrupt priority level 5, 10 

Interrupt vector add 5 

Interrupts -78 

IP register 47 

J 

Jumper configurations 10, 11 

L 

LED 6 

LSI-11 1 

M 

Maintenance adapter 9, 12 

Communication format 12 

Maintenance adapter pinouts 13 

Mass Storage Control Protocol 
See MSCP 

Media type H, 25 

Memory -1 

Message interrupts 45 

Message packets 43 

Message types -44 

MicroVAX 1 

MicroVMS 60 

MSCP 1,41 

See also Commands 

MSCP emulation 3 

MSCP devices 52 

MSCP ring buffers 57 
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N 

No sector interleaving., 



o 

OMB 

See WOMBAT utilities 
On-board WOMBAT utilities 3 

See WOMBAT 

Operating statistics & 

Operating systems supported 3 

Optimization. 24 

Overlap 2, 6 

See also Seek optimization 

P 

Partition 

See Virtual units 

Partitioning procedure 54 

PDP-11 boot program .6 

Power requirements .7 

Power-up 51 

PRIAM 806 Winchester 37 

Q 

Q-bus ; JL 

Q-bus address 52 

Q-bus interface .4 

Q-bus interface logic .4 

Q-bus loading .4 

Q-bus 

Q-bus interface... , 3 

Q-bus address 56 

R 

RCT 29,35,68 

Re-vectors 28 

Read look-ahead 2, 6, 26, 67 

Replacement Control Table 

See RCT 

Reset counters 28 

Response transmission .45 

Ring buffer capacity 5 

RS-232 

See Maintenance adapter 

RT-11 24 

RT11 54 
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s 

SA register .4,46,47 

Seek distance 28 

Seek optimization 2 6 

See also Optimization 

Sequential spin-up 4 

Serial number 26 

Short sectors/track 24 

Single drive configuration cable kit 9 

SMD 1)71 

SMD Interface 

See Drive interface 
Software interface 5 

See also MSCP emulation 
Starting WOMBAT 

See WOMBAT utilities 

Statistics recording 3 

Storage Module Drive 

See SMD 
SYSGEN 10,53,56,58 

T 

Temperature ,7 

Throughput j 

Track spiraling 24 

Transfer mode 4 

Transfer rate ,7 

TSXplus 24 

u 

Unit number 25 

Unit size 25 

Unit structure specification 
See WOMBAT utilities 

V 

Vector address 52, 56 

Virtual units 2,23,35 

w 

WOMBAT entry. & 

WOMBAT formatter ZZZZZZZZ.A 

WOMBAT interactive diagnostics .4 

WOMBAT self diagnostics ,4 ( 6 

WOMBAT utilities 5^17, 18 

Abort disk test 28 

Automatically replace bad blocks 31 

Bad block management menu options 31 

BINIT xi 

Change unit structure 27 

Compare unit to unit 34 
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Compute sectors per track 37 

Controller wide tuning parameters 23 > 26 

Copy unit to unit • ~4 

Create disk structure 23 

Disk geometry •" 

Disk structure g> f 

Disk structure menu options -f J **» fj» ^°» A/ 

Disk test menu options 28 > 29 ' 30 

Display disk structure 27 

Display error 2 

Display error statistics 30 

Display replaced bad blocks ^ 

Drive shadowing.. ~6 

Drive structure specification 23,24 

ECC validation • 30 

Enter defect map ^2 

Error recovery procedures • 36 

Format disk 27 

Halt CPU f 

IP register a ° 

LSI-11CPU 4: 

Manage bad blocks 2l 

Manually replace bad blocks 31 

Mastermenu ~~ 

MicroVAXII.... J 9 

9600 baud auxiliary terminal ■ .- 17 

No CPU • { 7 

ODT 17 

OMB 2 ^ 

Pattern test 30 

PCB 17 

Read all disk 29 

Read physical block 30 

Reset shadow units 34 

Self diagnostics 39 > ^ 

Set shadow units 33 

Set up new disk 22 

Shadow copy options ■ 33 

Shadow options ^2 

Shadow options menu option 32, 33 > 34 

Starting WOMBAT -J 7 - 18 

Test cache, RAM & ROM Option 31 

Test disk ^1 

Unit structure specification 23,25 

Update header blocks • 27 

W option 17 

WOMBAT initialization procedures - 18 

WOMBAT menu options 19 

Write disk ^9 

Write disk structure • 27 

30 



Zero error statistics - 

""'"". "...... 3 



Word transfer / block • - 5 



Write protect. 
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